小小小幸运 发表于 2025-4-1 02:56:25

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]
查看完整版本: C-悬挂指针和野指针