野指针是指指向不可用内存区域的指针。造成野指针的原因主要有:
- 指针变量未初始化:任何指针变量刚被创建时不会自动成为NULL指针,它的缺省值是随机的,会乱指一气。所以在创建指针的同时应当被初始化,要么将指针设置为NULL,要么让它指向合法的内存。
- 指针指向的内存被释放:当指针指向的内存被释放后,而指针本身没有设置为NULL,此时指针指向的就是“垃圾”内存。释放后的指针应立即将指针置为NULL,防止产生“野指针”。
- 指针操作超越变量作用域:不要返回指向栈内存的指针或引用,因为栈内存在函数结束时会被释放。
为了避免野指针的产生,应遵循以下方法:
- 指针初始化。
- 小心指针越界。
- 指针指向空间释放即使置NULL。
- 避免返回局部变量的地址。
堆区是调用malloc函数来申请内存空间,这部分空间使用完后需要调用free()函数来释放。
void * mallc(size_t);函数的输入是分配的字节大小,返回是一个void*型的指针,该指针指向分配空间的首地址,void *型指针可以任意转换为其他类型的指针。
void test(void)
{
int *p1=malloc(4);//申请4字节的空间
*p1=123;// 该空间赋值123
printf("0x%p:%d\n",p1,*p1);
printf("0x%p\n",&p1);
free(p1);
printf("0x%p:%d\n",p1,*p1);
p1 = NULL;
printf("0x%p\n",p1);
}
运行结果:
0x200003e8:123
0x200009d0
0x200003e8:0
0x00000000
int *p1=malloc(4);语句是申请了4个字节的空间,空间的首地址赋给指针p1,可以看到这个首地址是0x200003e8,存在是堆区;
printf(“0x%p\n”,&p1);指针p1本身也是需要存放的,p1本身是存放在栈区的0x200009d0;
free(p1);内存释放函数 free(开辟的内存的首地址) ,将内存标记为可用且将里面的内容清空为0,但指针p1还是指向这片空间。比较安全的做法是p1 = NULL;把p1指针释放,避免造成野指针。