问题背景
最近有小伙伴对于C语言中指针的运算有点疑问:指针变量加1之后,到底向后偏移了几个字节呢?示例代码如下,这段代码运行在32位CPU平台上:
#include<stdio.h>
#pragma pack(1)
struct tree
{
int height;
int age;
char tag;
};
#pragma pack()
int main()
{
char buffer[512] = {0};
struct tree *t_ptr = NULL;
char *t_ptr_new = NULL;
char *tmp_ptr = NULL;
tmp_ptr = buffer;
t_ptr = (struct tree *)tmp_ptr;
t_ptr_new = (char *)(t_ptr + 1);
printf("t_ptr_new point to buffer[%ld]\n", t_ptr_new - tmp_ptr);
return 0;
}
请问,指针变量t_ptr_new 指向数组buffer的哪个位置?
如果能快速得出答案,恭喜你,已经掌握指针算术运算的原理,以及结构体占用空间大小的计算。如果不能,也不要气馁,正好可以将这部分欠缺的知识补充上。下面,让我们来逐步揭开它的内幕。
结构体
C语言中struct声明创建一个数据类型(结构体),能将不同类型的对象聚合到一个对象中,用名字来引用结构体的各个组成部分。结构体的所有组成部分都存放在一段连续的内存中。指向结构的指针就是结构第一个成员的地址。
示例中结构体类型定义
#pragma pack(1)
struct tree
{
int height;
int age;
char tag;
};
#pragma pack()
结构体内部有三个成员变量,其中两个为int型,一个char型。编译器按照成员列表顺序挨个给每个成员分配内存。此结构体占用的内存空间是多少个字节呢?
height和age各占用4个字节,tag占用1个字节。那结构体占用的空间就是9个字节呗。是这样码?