作业12 (2023-05-15 指针概念)

发布于:2025-03-25 ⋅ 阅读:(18) ⋅ 点赞:(0)

第1题/共11题【单选题】

关于指针的概念,错误的是:( )

A.指针变量是用来存放地址的变量
B.指针变量中存的有效地址可以唯一指向内存中的一块区域
C.野指针也可以正常使用
D.局部指针变量不初始化就是野指针
回答正确

答案解析:

A:正确,指针变量中存储的是一个地址,指向同类型的一块内存空间
B:正确,地址是唯一的,一个指针变量中只能存储一个地址,因此可以唯一指向内存中的一块区域
C:野指针指向的空间时非法的,或者说该指针指向的空间已经不存在了,因此野指针不能使用
D:局部指针变量没有初始化时里面就是随机值,因此指向那个位置不一定,故将其看成是野指针
因此:选择C

第2题/共11题【单选题】

以下系统中,int类型占几个字节,指针占几个字节,操作系统可以使用的最大内存空间是多大:( )

A.32位下:4,4,2^32 64位下:8,8,2^64
B.32位下:4,4,不限制 64位下:4,8,不限制
C.32位下:4,4,2^32 64位下:4,8,2^64
D.32位下:4,4,2^32 64位下:4,4,2^64
回答正确

答案解析:

32位系统下:
int占4个字节,指针表示地址空间个数,总共有2^32个,故占4个字节
64位系统下:
int占4个字节,指针表示地址空间个数,总共有2^64个,故占8个字节
因此:选择C

第3题/共11题【编程题】

使用指针打印数组内容

作业内容
写一个函数打印arr数组的内容,不使用数组下标,使用指针。
arr是一个整形一维数组。

我的答案:

#include <stdio.h>

int main()
{
   
	int arr[10] = {
    0,1,2,3,4,5,6,7,8,9 };
	int* p = arr;
	int* pend = arr + 9;

	while (p <= pend)
	{
   
		printf("%d ", *p);
		p++;
	}

	return 0;
}

参考答案:

#include <stdio.h>
int main()
{
   
    int arr[] = {
   1,2,3,4,5,6,7,8,9,10};
    //在这里完成代码
    // 分析:因为数组中存储的元素类型是int类型的,因此只要给一个int的指针,依次取索引数组中的每个元素即可
    int* p = arr;  // 数组名代表数组首元素的地址
    for(int i = 0; i < sizeof(arr)/sizeof(arr[0]); ++i)
    {
   
        printf("%d ", *p);   // *p: 取到p所指向位置的元素
        ++p;                 // 获取p的下一个位置
    }
    
   	return 0;
}

第4题/共11题【单选题】(这道题当时不会做,做错了)

在小端机器中,下面代码输出的结果是:( )

#include <stdio.h>
int main()
{
   
    int a = 0x11223344;
    char *pc = (char*)&a;
    *pc = 0;
    printf("%x\n", a);
    return 0;
}

A.00223344
B.0
C.11223300
D.112233
(回答错误)我的答案:A
(正确答案是:C)

答案解析:

假设,a变量的地址为0x64,则a变量在内存中的模型为:
0x64| 44 |
0x65| 33 |
0x66| 22 |
0x67| 11 |

char类型的指针变量pc指向只能指向字符类型的空间,如果是非char类型的空间,必须要将该空间的地址强转为char类型。
char pc = (char)&a; pc实际指向的是整形变量a的空间,即pc的内容为0x64,即44,
*pc=0,即将44位置中内容改为0,修改完成之后,a中内容为:0x11223300

低地址 高地址
0X 44 33 22 11

因此:选择C

涉及的知识点:
大端存储模式:是指数据的低位保存在内存的高地址中,而数据的高位,保存在内存的低地址中。
小端存储模式:是指数据的低位保存在内存的低地址中,而数据的高位,保存在内存的高地址中。

第5题/共11题【单选题】

下面代码的结果是:( )

#include <stdio.h>
int main()
{
   
  int arr[] = {
   1,2,3

网站公告

今日签到

点亮在社区的每一天
去签到