结构体相关的计算(结构体指针加一以及强制类型转换后加一)

时间:2023-01-11 18:08:13

定义一个结构体,大小为16个字节

struct AAA
{
	long 1A1;
	char cA2;
	char cA3;
	long 1A4;
	long 1A5;
}*p;
int main()
{
	p = (struct AAA*)0x100000;
	printf("%p\n", p + 0x1);
	printf("%p\n", (unsigned char)p + 0x1);
	printf("%p\n", (unsigned int)p + 0x1);
	printf("%p\n", (unsigned long*)p + 0x1);
	printf("%p\n", (unsigned char*)p + 0x1);
	printf("%p\n", (char *)p + 0x1);
	printf("%p\n", (char **)p + 0x1);


	system("pause:");
	return 0;
}
运行结果如下:

结构体相关的计算(结构体指针加一以及强制类型转换后加一)

这下我们就得分析一下为什么结果会是这样。

1.p(0x100000)是一个指针,指向占16个字节的结构体,加一跳过整个结构体。(p+0x1=0x100010)

2.将p强制类型转化为无符号长整型,是一个数字,加1直接加1。  ((unsigned char)p + 0x1=0x1000001)

3.将p强制类型转化为无符号整型,是一个数字,加1直接加1。       ((unsigned int)p + 0x1=0x1000001)

4.p是一个指针,指向无符号长整型,占4个字节。                                (unsigned long*)p + 0x1=0x1000004)

5.p是一个指针,指向无符号字符,占1个字节。                                    (unsigned char*)p + 0x1=0x1000001)

6.p是一个指针,指向字符,占1个字节。                                              (char *)p + 0x1=0x1000001)

7.p是一个二级指针,里边存的是地址,占4个字节。                           ((char **)p + 0x1=0x1000004)