C语言--- 指针运算笔试题详解

目录

题目1:

题目2:

题目3:

题目4:

题目5:

题目6:

题目7:


题目1:

#include 
int main()
{
     int a[5] = { 1, 2, 3, 4, 5 };
     int *ptr = (int *)(&a + 1);
     printf( "%d,%d", *(a + 1), *(ptr - 1));
     return 0;
}

解析:

a是数组首元素的地址,类型为int*,+1跳过一个元素,再解引用就是第二个元素。

&a是整个数组的地址,+1跳过整个数组,再强制类型转化为int*类型,-1就是数组最后一个元素的地址,解引用后就是最后一个元素。

答案:

2,5

题目2:

struct Test
{
	int Num;
	char* pcName;
	short sDate;
	char cha[2];
	short sBa[4];
}*p = (struct Test*)0x100000;
//在X86环境下
//假设结构体的⼤⼩是20个字节
//程序输出的结构是啥?
int main()
{
	printf("%p\n", p + 0x1);
	printf("%p\n", (unsigned long)p + 0x1);
	printf("%p\n", (unsigned int*)p + 0x1);
	return 0;
}

解析:

p是一个指针,类型是struct Test*,是由十六进制数字0x100000强制类型转换为struct Test*类型所得到的。

0x1就是1,p+1就是跳过一个元素,一个结构体的大小是20个字节,地址就加20,变成0x00100014.将p强制类型转化为unsigned long类型的值再加1,就是单纯的数学运算,结果是0x00100001.将p强制类型转化为unsigned int*类型的指针&

你可能感兴趣的:(C,c语言,算法,开发语言)