结构体指针在使用完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,还是野指针。的主要内容,如果未能解决你的问题,请参考以下文章