文章目录
- 一、指针运算 与 指针内存操作
- 二、结构体偏移量计算
一、指针运算 与 指针内存操作
指针变量算术运算 ( 指针可以是任意值 ) : 指针 是一个变量 , 如果对指针进行 算术 / 逻辑 等运算 , 其效果等同于 对 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 成员的偏移量 ;