三叶草 发表于 2021-12-29 16:46:30

初夏小谈:野指针(隐形杀手):干翻了多少英雄汉(干货!!!)




前言:
如果学习了C语言,没有好好研究内存管理的话,恐怕C语言还是很模糊吧,当我跟着学校老师的步伐学完C语言之后,我可以说是和小白没什么两样。不是说老师教的不好,只是C语言真的太经典了。如果对它没有精心的去好好研究,那真的入门都不算。当我第一次学完C语言时,感觉脑子很乱,傻傻地连指针都搞不清楚,总想着去掉那个星号(*)哈哈 ^_^,但之后我真的不想为了考试而学C语言,那样会失去学习的乐趣以及动力。找C语言各种书查看,学习终于有了一定的进步,当然还是很菜哈哈。


好了步入今天正式的主题《C语言之野指针》
来说说野指针(也叫悬垂指针)这玩意,这个玩意说实话真的恶心,我敲代码期间踩过不少的坑,这是bug的一个重大来源,而且不易被发现。所谓野指针就是一个指针指向了一块不属于它管理范围的内存。常见几种情况。
第一种:就是在函数体中定义并初始化了一个数组,然后用指针指向这个数组,返回这个指针,在main函数中接收这个指针。这一类。不明白?举个例子:
char* Test2()
{
char arr[] = "abcdef";
char* ptr = &arr;
return ptr;
}就像这一类,在mian函数中是可以接收到原来arr数组的地址但是,那块内存是在栈上开辟的函数结束时,就已经被释放,不归指针所管理。访问内存出错。
第二种:就是动态开辟内存后,及时free了,虽然用free这把刀斩断了指针和指向了动态开辟的那块内存,但是没有把这个指针置NULL,这个NULL就像当与栓野狗的链子(当然野狗就是那个指针),那你如果不栓起来,它就会瞎搞。举个例子:

#define _CRT_SECURE_NO_WARNINGS
#include<stdio.h>
#include<stdlib.h>
#include<string.h>

void Test()
{
char* ptr = (char*)malloc(1024);
strcpy(ptr, "hello C");
free(ptr);

if (NULL != ptr)
{
    strcpy(ptr, "C NiuBi");
}
printf(ptr);
}

int main()
{
Test();
system("pause");
return 0;
}
代码中条件并没有卵用,它还会执行。将会出错。因为那块内存已经被释放。不属于它。虽然ptr里面存储的是已经释放的内存地址但它和释放的内存是两路人,两者没有什么联系,要说强行联系,只能说指针恋恋不舍原来的内存就存了一份内存的影子罢了。


​珍&源码  ​ 




https://blog.51cto.com/u_15091844/4858555
页: [1]
查看完整版本: 初夏小谈:野指针(隐形杀手):干翻了多少英雄汉(干货!!!)