文章目录
一、不允许向 NULL 地址写入数据
二、不允许不断地改变指针指向
三、字面量存放位置
一、不允许向 NULL 地址写入数据
声明指针变量 , 并为其 设置 NULL 初始值 , NULL 就是 0 ;
char *p = NULL;
注意 , 此时一定不能访问 p 指针变量指向的地址 , 0 地址是操作系统保护地址 , 读写该地址的数据 , 都会报错 ;
C/C++ 中的 NULL 的值为 0 ;
#ifndef NULL #ifdef __cplusplus #ifndef _WIN64 #define NULL 0 #else #define NULL 0LL #endif /* W64 */ #else #define NULL ((void *)0) #endif #endif
如果在声明指针后 , 向 NULL 地址写出数据 , 执行时直接报错 ;
错误代码示例 :
#include <stdio.h> #include <stdlib.h> int main() { // 声明指针变量 , 并为其设置 NULL 初始值 // NULL 就是 0 char *p = NULL; // 向 0 地址写出数据会报错 strcpy(p, "123"); // 打印 p 指针内容 printf("%s\n", p); return 0; }
执行结果 : 上述代码执行时 , 没有任何响应 ;
二、不允许不断地改变指针指向
指针变量 声明后 , 不断修改 指针变量的值 , 就是 不断改变 指针变量 指向内存空间的位置 ;
上述操作会导致 多个指针变量 , 会 指向同一块内存空间 , 这种做法不会出错 , 但是 容易出现 BUG , 一旦出问题根本找不到原因 ;
代码示例 :
#include <stdio.h> #include <stdlib.h> int main() { // 声明指针变量 , 并为其设置 NULL 初始值 // NULL 就是 0 char *p = NULL; char *p2 = NULL; // 堆内存中申请 20 字节数据 p2 = (char *)malloc(20); // 为内存赋值 strcpy(p2, "1234567890"); int i = 0; for(i = 0; i < 10; i++) { // 借用 p 指针遍历 p2 指针指向的内存 p = p2 + i; printf("%c\n", *p); } return 0; }
执行结果 :
三、字面量存放位置
在代码中 , 如果出现 0 , 1 等字面量 , 如
int a = 0;
上述 字面量 0 没有放在栈区 , 字面量 无法取地址 , 没有放在 栈区 和 堆区 ;