文章目录
一、指针运算 与 指针内存操作
二、结构体偏移量计算
一、指针运算 与 指针内存操作
指针变量算术运算 ( 指针可以是任意值 ) : 指针 是一个变量 , 如果对指针进行 算术 / 逻辑 等运算 , 其效果等同于 对 int 整型变量 进行 算术运算 , 编译运行 并不会报错 ;
char *p = NULL; // 下面的操作 编译 运行 都可以通过 p + 1; p - 1; p * 20;
指针进行内存操作 ( 指针必须合法 ) : 但是注意 , 如果要 对 指针 进行内存操作 , 如使用 * 获取指针指向的数据 , 或者使用 memset 修改指针指向的数据 , 或者 free 释放指针 , 要操作的 指针变量 , 必须是 合法的指针 ;
char *p = NULL; // 下面的操作 涉及使用指针进行内存操作 , 编译通过 , 运行时报错 *p; free(p);
二、结构体偏移量计算
定义结构体 :
/** * @brief The Student struct * 定义 结构体 数据类型 , 同时为该结构体类型声明 别名 * 可以直接使用 别名 结构体变量名 声明结构体类型变量 * 不需要在前面添加 struct 关键字 */ typedef struct Student { // 声明变量时 , 会自动分配这 5 字节内存 // 赋值时 , 可以直接使用 = 赋值字符串 char name[5]; // 0 ~ 4 字节 int age; // 5 ~ 8 字节 // 声明变量时 , 只会为 4 字节指针分配内存 // 具体的 字符串内存 需要额外使用 malloc 申请内存 // 赋值时 , 必须使用 strcpy 函数 , 向堆内存赋值 char *address; // 9 ~ 12 字节 }Student;
求上述 Student 结构体的 age 成员的偏移量 ;
将 0 地址 , 按照 Student 结构体 内存 形式进行解释 , 即将 0 地址指针 强转为 Student * 类型 ;
(Student *)0
然后取上述 Student * 指针类型的 age 成员 ;
((Student *)0)->age
获取上述 age 成员的地址 ;
&(((Student *)0)->age)
将 age 成员的地址转为 int 类型 ;
(int)&(((Student *)0)->age)
上述获取的就是 Student 结构体中 , age 成员的偏移量 ;