题目2:
struct MyStruct
{
int num;
char* pcname;
short sdate;
char cha[2];
short sba[4];
}*p;
//结构体大小为32字节
//p=0x100000
int main()
{
p = 0x100000;
printf("%p\n", p + 0x1);
//p:结构体指针,+1=下一个结构体指针,所以 p + 1 的地址比 p 高32字节
//p+1=p+结构体大小=p+32(10进制)=0010 0000+0000 0020=0010 0020
printf("%p\n", (unsigned long)p + 0x1);
//0x10 0000(16进制)=1048576(10进制)
//加1会增加地址的值,而不是指向下一个结构体
//1048576+0x1(16进制)=1048576+1(10进制)=1048577=0010 0001(16进制)
printf("%p\n", (unsigned int*)p + 0x1);
//unsigned int*:整型指针类型,指针+1=下一个指针
// 尽管平台是64位的,但是 unsigned int 的大小在几乎所有平台上都是4字节(32位),而不是8字节(64位)
//p+1=p+4(64平台)=0010 0000+4(16进制)=0010 0000+8(10进制)=0010 0004
return 0;
}
题目1:
int main()
{
int a[4] = { 1,2,3,4 };
int* ptr1 = (int*)(&a + 1);
//&a + 1:指向元素4右边的地址
//(int*)(&a + 1):强制转换为int*类型
int* ptr2 = (int*)((int)a + 1);
//(int)a:数组首元素
printf("%x,%x\n", ptr1[-1], *ptr2);
//ptr1[-1]=*(ptr1+(-1))=*(ptr1-1)=指向元素4右边的地址向左边移动一位=4
return 0;
}
解析: