结构体指针在使用完free后,该指针所指向的内存区域是啥,这个指针是变成了NULL,还是野指针。

Posted

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了结构体指针在使用完free后,该指针所指向的内存区域是啥,这个指针是变成了NULL,还是野指针。相关的知识,希望对你有一定的参考价值。

不同的编译器会有区别,例如keil在free后该片内存区域的数据还是原来的数据,不过系统知道,这篇内存是不用的内存,下次可能在分配内存的时候就会被占用,有的编译器则是直接清除free后的内存区域,变成NULL,或者一些看不懂的数据,但是总归一点,这片内存已经可以被再次利用了。至于指针也是不同编译器也会有所区别,如果不放心,还怕会变成野指针可以在free后,将该指针赋值为NULL。望采纳 参考技术A free后,该指针指向的内存区域被系统回收,但里面内容还是释放前的内容,只是被系统回收后,有可能马上又被其他地方申请出来使用,所以free后再去读取这块内存的内容就可能是不可预知的内容了。
free函数不会改变被释放指针的值,也就是说free后该指针还指向被释放的空间,一般需要特别对其赋值为NULL。
参考技术B

野指针,所以需要再手工把指针置零

简单测试一下就能知道,看下面的程序与运行结果:

参考技术C 结构体指针在使用完free后,该指针所指向的内存区域还是原来的区域,除非该地区又被系统派别的用处。
_msize() 返回 动态分配的 实际 内存大小。

#include<stdio.h>#include<stdlib.h>
#include<malloc.h>

struct ss int x,y;
;

int main()

struct ss *S;
int i;
S = (struct ss*) malloc (sizeof(struct ss) * 3);
for (i=0;i<3;i++) S[i].x=i; S[i].y=i*10;

for (i=0;i<3;i++) printf("%d ", S[i].x);for (i=0;i<3;i++) printf("%d ", S[i].y);
printf("\nsize=%d\n", _msize(S));

free(S); // 释放for (i=0;i<3;i++) printf("%d ", S[i].x);
for (i=0;i<3;i++) printf("%d ", S[i].y);
printf("\nsize=%d\n", _msize(S));

return(0);

输出结果:
0 1 2 0 10 20
size=32
0 1 2 0 10 20
size=0
===
释放后,内存大小为0,但数值还在。
参考技术D 规划建议建议提建议

C 语言结构体 ( 结构体浅拷贝 )





一、结构体浅拷贝与深拷贝



结构体 中 嵌套了 指针 , 指针指向的内存 , 如果需要 malloc 在堆内存中 分配内存 , 如果在 该类型 结构体变量 之间互相赋值 ,

  • 如果直接赋值 , 就是浅拷贝 ;
  • 如果赋值时 , 重新为 指针变量 在堆内存中重新申请内存 , 拷贝数据 , 就是 深拷贝 ;

浅拷贝 只会 拷贝 指针变量的值 , 不会拷贝 指针变量 指向的 内存空间的 数据 ;





二、结构体浅拷贝



结构体浅拷贝 : 下面两种方式的拷贝 , 是结构体的浅拷贝 ;

  • 直接拷贝结构体内存 :
    // 结构体内存拷贝
    // 该拷贝是浅拷贝
    memcpy(to, from, sizeof (Student));
  • 使用 = 操作拷贝 : 只会将 结构体 变量的 内存 , 从 from 指针指向的地址 , 拷贝到 to 指针指向的地址 ;
    // 结构体直接赋值 , 与上面的代码作用相同
    // 该拷贝也是浅拷贝
    *to = *from;




三、结构体浅拷贝代码示例



代码示例 :

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

/**
 * @brief The Student struct
 * 定义 结构体 数据类型 , 同时为该结构体类型声明 别名
 * 可以直接使用 别名 结构体变量名 声明结构体类型变量
 * 不需要在前面添加 struct 关键字
 */
typedef struct Student

    // 声明变量时 , 会自动分配这 5 字节内存
    // 赋值时 , 可以直接使用 = 赋值字符串
    char name[5];
    int age;

    // 声明变量时 , 只会为 4 字节指针分配内存
    // 具体的 字符串内存 需要额外使用 malloc 申请内存
    // 赋值时 , 必须使用 strcpy 函数 , 向堆内存赋值
    char *address;
Student;

/**
 * @brief copy_student 执行浅拷贝操作
 * @param to
 * @param from
 */
void copy_student(Student *to, Student *from)

    // 结构体内存拷贝
    // 该拷贝是浅拷贝
    memcpy(to, from, sizeof (Student));

    // 结构体直接赋值 , 与上面的代码作用相同
    // 该拷贝也是浅拷贝
    //*to = *from;




/**
 * @brief 主函数入口
 * @return
 */
int main(int argc, char* argv[], char**env)

    Student s1;
    Student s2;

    // 为 s1.age 赋值
    s1.age = 18;

    // 为 s1.name 赋值
    // 该成员是 数组 , 在 s1 结构体变量声明时 , 就分配好了内存
    strcpy(s1.name, "Tom");

    // 给 s1.address 在堆内存分配内存
    s1.address = (char *)malloc(20);
    strcpy(s1.address, "Beijing");


    // 将 s1 赋值给 s2
    copy_student(&s2, &s1);

    printf("s1 : name = %s, age = %d, address = %s\\n", s1.name, s1.age, s1.address);
    printf("s2 : name = %s, age = %d, address = %s\\n", s2.name, s2.age, s2.address);

    // 命令行不要退出
    system("pause");
    return 0;

执行结果 :

s1 : name = Tom, age = 18, address = Beijing
s2 : name = Tom, age = 18, address = Beijing
请按任意键继续. . .

以上是关于结构体指针在使用完free后,该指针所指向的内存区域是啥,这个指针是变成了NULL,还是野指针。的主要内容,如果未能解决你的问题,请参考以下文章

对 NULL 指针连续 free多次会出错吗?为啥?

指针free后还存在吗?

关于C语言free函数的问题

野指针与内存操作

为啥free函数不在释放内存后,将指针置NULL,野指针有啥用

quiz 3