free()函数释放空间失败的原因

本文通过一个简单的C语言程序示例,深入分析了内存泄漏的原因及解决方案。文章指出,当使用malloc分配内存时,未正确预估所需空间大小,会导致输入字符串超出分配内存范围,从而引发内存泄漏和堆栈损坏的问题。作者建议,在使用malloc时,应确保分配足够大的内存空间,例如增加1以容纳字符串结束符。

转载于:https://blog.youkuaiyun.com/qq_40977765/article/details/89191053

    
#include<stdio.h>
#include<malloc.h>
#include<string.h>
#pragma warning (disable:4996)
int main()
{
	char *temp;

	temp = (char *)malloc(sizeof(char));

	printf("temp:");
	scanf("%s", temp);
	printf("%s", temp);
	puts(temp);

	free(temp);//这里会释放失败

	printf("success\n");
	getchar();
	getchar();
	return 0;
}

PS:#pragma warning (disable:4996)仅用在2017版VS中无视安全检查,getchar()用于暂停运行。

运行结果:

输入“123”能够正常输出“123”,但是free()函数不能正常执行。出现HEAP CORRUPTION DETECTED的错误。

原因:temp只向系统要求开辟一个空间,而实际上输入字符串超过了开辟的空间存贮量。
解决方法:使用malloc申请足够的空间。比如:temp = (char *)malloc(sizeof(char)+1);

在编程中,申请空间释放空间是内存管理的重要部分。申请空间指的是在程序运行时动态分配内存,而释放空间则是将再使用的内存归还给系统。以下是一些常见的方法和注意事项: ### 申请空间 1. **C语言中的`malloc`函数**: `malloc`函数用于在堆上动态分配内存。它返回一个指向分配的内存块的指针,如果分配失败,则返回`NULL`。 ```c #include <stdlib.h> int *ptr = (int *)malloc(sizeof(int) * 10); // 分配10个int大小的内存 if (ptr == NULL) { // 处理分配失败的情况 } ``` 2. **C++中的`new`运算符**: `new`运算符用于在堆上动态分配内存,并调用构造函数初始化对象。 ```cpp int *ptr = new int[10]; // 分配10个int大小的内存 if (ptr == nullptr) { // 处理分配失败的情况 } ``` ### 释放空间 1. **C语言中的`free`函数**: `free`函数用于释放之前通过`malloc`、`calloc`或`realloc`分配的内存。 ```c free(ptr); // 释放ptr指向的内存 ptr = NULL; // 防止悬挂指针 ``` 2. **C++中的`delete`运算符**: `delete`运算符用于释放通过`new`分配的单个对象内存。 ```cpp delete ptr; // 释放ptr指向的内存 ptr = nullptr; // 防止悬挂指针 ``` 3. **C++中的`delete[]`运算符**: `delete[]`运算符用于释放通过`new[]`分配的数组内存。 ```cpp delete[] ptr; // 释放ptr指向的数组内存 ptr = nullptr; // 防止悬挂指针 ``` ### 注意事项 - **内存泄漏**:如果释放再使用的内存,会导致内存泄漏,最终可能导致系统内存耗尽。 - **悬挂指针**:释放内存后,指针仍然指向该内存地址,可能会导致未定义行为。应在释放内存后将指针置为`NULL`。 - **多次释放**:同一块内存被多次释放会导致程序崩溃。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值