C-悬挂指针和野指针
一、题目形貌字符指针传址进入函数,在函数内将指针指向的内存释放、指针置空,在函数外指针地址仍不变;此时访问该悬挂指针指向的内存可能会导致程序非常等题目。
二、悬挂指针和野指针
1.悬挂指针
悬挂指针是一个指针,它指向的内存在之前是有用的,但由于某些操作(如内存释放)后变得不再有用。悬挂指针仍然保留着指向已释放内存的地址。
static char* g_str = NULL;
static void test(char* str)
{
//str传址拷贝至函数内,在函数里将str置空,只是下文中str为空指针无法访问,未改变g_str的地址
str = NULL;
}
int main()
{
g_str = (char*)malloc(32);
free(g_str);
test(g_str);
printf("str addr is %p", g_str); //地址非空
if(g_str != NULL) {
printf("str addr is %s", g_str); //访问已释放内存
}
} 导致的题目:
1. 数据不一致:如果悬挂指针指向的内存被操作体系接纳并重新分配给其他用途,通过悬挂指针访问该内存可能导致数据不一致;
2. 内存走漏:如果悬挂指针没有被置为 NULL,内存未接纳,可能导致内存泄漏;
3. 段错误:如果指针指向的内存已释放,再次访问指针,通常会导致程序触发段错误。
2.野指针
野指针是一个指针,它指向的内存地区是未界说的,或者不是当前程序分配的内存。这可能包括指向已经被释放的内存、未初始化的指针、或者指向程序栈之外的内存。
1. 未初始化的指针
int main() {
int *p; // 未初始化的指针
printf("Value at p: %d\n", *p); // 未定义行为,可能导致程序崩溃
return 0;
} 2. 指向未界说的内存
int main() {
int arr = {1, 2, 3, 4, 5};
int *p = arr + 5; // 指向数组最后一个元素的下一个位置
// p 现在是一个野指针,因为它超出了数组的边界
printf("Value at p: %d\n", *p);
return 0;
} 3. 函数返回局部变量的地址
int *function() {
int local_var = 42;
return &local_var; // 返回局部变量的地址
}
int main() {
int *p = function();
printf("Value at p: %d\n", *p); // 未定义行为,因为 local_var 已经超出作用域
return 0;
} local_var变量在函数实行竣事时,内存会被释放,此时返回函数的地址;使得p指向了未界说的内存,可能会程序非常或读取到错误数据。
总结
函数内需要谨慎进行址转达,可以通过动态申请内存、使用后释放的方式,防止指针指向未界说内存;为指针动态申请内存、释放内存后,需要将指针置空,防止出现悬挂指针访问非常情况。
免责声明:如果侵犯了您的权益,请联系站长,我们会及时删除侵权内容,谢谢合作!更多信息从访问主页:qidao123.com:ToB企服之家,中国第一个企服评测及商务社交产业平台。
页:
[1]