1.判断下列三个表达式的输出是多少?
struct Test
{
int Num;
char *pcName;
short sDate;
char cha[2];
short sBa[4];
}*p;
//假设p 的值为0x100000。 如下表表达式的值分别为多少?
//已知,结构体Test类型的变量大小是20个字节
int main()
{
printf("%p\n", p + 0x1);
printf("%p\n", (unsigned long)p + 0x1);
printf("%p\n", (unsigned int*)p + 0x1);
return 0;
}
a.先分析根据结构体定义的概念可知这个p为这个结构体的指针,p+0x1(16进制),也就是p+1,p为一个指针+1也就是跳过一个p相关的类型。所以为p的地址+上它所占的字节20为:0x100014。
b.第二个跟第一个相同,但要进行加一时因为其类型被强制转成(unsigned long)是一个无符号的长整形,所以直接整数加一,为:0x100001
c.第三个同上,因为被转化为(指针类型)所以指针为四个字节所以直接加四,为:0x100004
2.判断下面的输出值
int main()
{
int a[4] = { 1, 2, 3, 4 };
int* ptr1 = (int*)(&a + 1);
int* ptr2 = (int*)((int)a + 1);
printf("%x,%x", ptr1[-1], *ptr2);//4
return 0;
}
a.&a因为a为数组名,对其取地址直接变为数组指针int (*)[4],当其进行加一因为是指针类型,所以直接跳过一个指针类型的长度,该数组指针类型长度为4*4个字节,跳到了数组元素4的后一位,并转换成int*类型存在指针变量ptr1中,当其在底下进行打印时,进行了ptr1[-1]操作,该操作相当于 *(ptr1-1),即ptr1这个指针向前移一位并且解引用,最后再以%x打印16进制,为:4.
b.画图解答:
3.判断下面输出值
int main()
{
int a[5][5];
int(*p)[4];
p = a;
printf("%p,%d\n", &p[4][2] - &a[4][2], &p[4][2] - &a[4][2]);//
return 0;
}
a.图解
4.判断下面输出值。
int main()
{
char* c[] = { "ENTER","NEW","POINT","FIRST" };
char** cp[] = { c + 3,c + 2,c + 1,c };
char*** cpp = cp;
printf("%s\n", **++cpp);//point
printf("%s\n", *-- * ++cpp + 3);//er
printf("%s\n", *cpp[-2] + 3);//rt
printf("%s\n", cpp[-1][-1] + 1);//ew
return 0;
}
图解: