理论知识:指针+1所增加的字节数是这个指针指向的变量的长度。
本文通过代码运行输出,验证一级指针+1增加的字节数依变量而定,二级指针+1是增加4个字节。代码说明在后面。
typedef struct
{
int a;
char b;
short c;
long d;
}Test;
Test s1;//结构体
Test* p = &s1;//一级指针
Test** pDouble = &p;//二级指针
int main()
{
int offset1=0,offset2=0,offset3=0,offset4=0;
/*一级指针*/
Test *temp1=NULL,*temp2=NULL;
/*二级指针*/
Test **temp3=NULL,**temp4=NULL;
//一级指针+1的偏移量
temp1 = p;
temp2 = p+1;
offset1 = temp2-temp1;//两个指针间的元素数目
offset2 = (unsigned int)temp2-(unsigned int)temp1;//两个指针间的字节数
//二级指针+1的偏移量
temp3 = pDouble;
temp4 = pDouble+1;
offset3 = temp4-temp3;//两个指针间的元素数目
offset4 = (unsigned int)temp4-(unsigned int)temp3;//两个指针间的字节数
printf("struct:%d\r\n",sizeof(Test));
printf("%p,%p,%d,%d\r\n",temp1,temp2,offset1,offset2);
printf("%p,%p,%d,%d\r\n",temp3,temp4,offset3,offset4);
getch();
return 0;
}
验证思路:
先定义指针,获取这个指针的地址,和指针+1后的地址,两个地址作差得到增加的字节数。
变量定义:
结构体:定义一个名为“Test:”的结构体 ;//这个结构体的大小后面会直接用sizeof输出
结构体变量:s1;//Test结构体类型的变量
一级指针:p;//指向s1的指针
二级指针:pDouble;//指向p的指针(指针的指针 即为 二级指针)
代码说明:
一级指针说明:
一级指针temp1指向p,temp2指向p+1,两者作差即得到增加的字节数。
需注意:指针的加减计算,是在地址加减后,编译器会自动除以‘’指针指向的元素的大小‘’,所以temp2-temp1等于1,意味着只增加了一个元素。只有将指针转化为int型后,编译器才不会加入对指针的自动处理,才能真正得到这两个地址之间的差值,(unsigned int)temp2-(unsigned int)temp1等于12,也就是结构体的字节数。
二级指针说明:
与一级指针类似,二级指针temp3指向pDouble,temp4指向pDouble+1,两者作差即得到增加的字节数。
因为二级指针指向的是指针,指针这个变量的大小是固定的,4字节,所以二级指针+1所增加的字节数固定是4。与一级指针指向的元素大小无关。
struct:12 //结构体大小
00417570,0041757C,1,12 //这四个数分别是一级指针p指向的地址,p+1指向的地址,指针差(offset1),地址差(offset2)
00417000,00417004,1,4//这四个数分别是二级指针pDouble指向的地址,pDouble+1指向的地址,指针差(offset3),地址差(offset4)
总结:
所有指针都符合这个规律:指针+1意味着指向的地址向下偏移了一个元素,所增加的字节数等于元素的大小。所以一级指针+1增加的字节数是不定的,和它指向的元素大小有关。二级指针是其中的特例,因为它指向的元素只有指针,而指针就是4字节,所以二级指针+1是固定增加了4字节。