什么是内存泄漏及如何防护内存泄漏

目录


前言

最近阅读量很低啊(⁠ ⁠≧⁠Д⁠≦⁠)


什么是内存泄漏

内存泄漏(Memory Leak)指在程序运行过程中,分配的内存空间在不再使用后未被正确释放或回收,导致这部分内存无法再被其他程序或操作系统使用,最终造成内存资源的浪费或不足。

当一个程序运行时,它需要在内存中分配一定的空间来存储数据和临时变量。

通常,在不再需要使用这些内存空间时,程序会将其释放给操作系统或其他程序使用。然而,如果程序中存在内存泄漏的问题,这些不再使用的内存空间将无法正确释放,导致内存的持续增加。

内存泄漏可能会导致以下问题:

  1. 内存资源浪费:未释放的内存占用会逐渐增加,最终占用过多的内存资源,导致系统整体性能下降。
  2. 系统崩溃或异常:当内存泄漏达到一定程度时,系统可能会因为内存不足而崩溃或出现异常错误。
  3. 系统性能下降:内存泄漏会导致资源的浪费,使得系统的响应速度变慢,甚至造成系统运行变得不稳定。

内存泄漏的常见原因包括未正确释放动态分配的内存、循环引用、缓存未清理等。内存泄漏可以通过使用合适的内存管理技术、编写高质量的代码以及使用内存分析工具来预防和修复。

示例一

c 复制代码
#include <stdio.h> 
#include <stdlib.h>    
int main() 
{
int *p;
p = (int*)malloc(sizeof(int) * 10);
//动态分配10个int类型变量的内存
//如果调用malloc函数失败,p会变成空指针,需要检查p是否为空指针再进行下一步操作
return 0;
}

讲解:

代码中的内存泄漏是指在malloc()函数分配内存后,没有使用free()函数释放该内存。由于没有释放这部分内存,在程序运行结束后,操作系统将无法回收这部分未释放的内存空间。

解决办法:

要解决这个问题,需要在不再使用动态分配的内存空间时,使用free()函数将其释放。例如,在程序结束前添加free(p);来释放p指向的内存空间。

示例二

c 复制代码
#include <stdio.h>
#include <stdlib.h>
void memoryLeak()
{
int *ptr = (int*)malloc(sizeof(int));    // 没有释放动态分配的内存,导致内存泄漏
// 这部分内存无法被其他程序或操作系统使用
}
int main()
{
memoryLeak();
printf("内存泄漏示例\n");
return 0;
}

讲解:

这段代码中,我们定义了一个名为memoryLeak()的函数。在函数内部,我们使用malloc()函数动态分配了一块int类型的内存,并将其地址赋值给ptr指针。但是,在函数结束之前,没有使用free()函数释放这部分内存,导致内存泄漏的发生。

main()函数中,我们调用了memoryLeak()函数,并在其后打印一条简单的消息。然而,由于存在内存泄漏问题,释放的内存无法被回收,这可能导致系统的内存资源被浪费,最终可能会导致系统性能下降或者崩溃。

解决办法:

应该在不再需要使用动态分配的内存时,使用free()函数显式地释放内存,例如在memoryLeak()函数末尾添加free(ptr);语句。这样可以确保在不使用内存时能够释放它,避免内存泄漏问题的发生。

特殊版本

c 复制代码
#include <stdio.h> 
#include <stdlib.h>
int main()
{
int *p = (int *)malloc(sizeof(int));
// 申请动态内存
*p = 123;
printf("*p = %d\n", *p);
// 输出 123
free(p);
// 释放内存
printf("*p = %d\n", *p);
// 错误: 程序运行错误(或者段错误)
return 0;
}

这段代码的功能是先通过malloc()函数动态分配了一个int类型大小的内存空间,并将其地址赋给指针变量p。然后,将整数值123存储在该内存空间中,并通过printf()函数打印出该值。

接下来,使用free()函数释放了之前分配的内存空间。最后,在已经释放了内存空间的情况下,尝试使用指针p访问该内存空间并打印其值。这是错误的行为,因为该内存空间已被释放,不再属于程序的可访问范围,因此会导致运行错误或段错误。

因此,代码的最后一行会导致程序出现错误。为了避免这种错误,应该在释放内存后避免继续使用指向已释放的内存地址的指针。

(如果看不懂看这里,说白了就是内存空间已经释放仍访问指针)

危害:

  1. 未定义的行为:尝试访问已释放的内存是未定义的行为。在这种情况下,代码中的printf("*p = %d\n", *p);语句会导致程序出现错误。这可能会导致程序崩溃或产生不可预测的行为。
  2. 内存泄漏:尽管在代码中使用了free(p)来释放内存,但是在释放之后仍然试图访问已释放的内存空间。这可能会导致内存泄漏,因为释放的内存无法被其他程序或操作系统回收,从而浪费内存资源。
  3. 安全隐患:如果被泄漏的内存中包含敏感数据,可能会导致安全隐患。其他恶意程序或黑客可能会利用这些被泄漏的内存来获取敏感信息,从而威胁系统的安全性。

总结/结尾

我准备用故事来讲的可我我没写脚本就更了这期文章

相关推荐
红花与香菇2____1 小时前
【学习笔记】STM32F407探索者HAL库开发(四)F103时钟系统配置
c语言·笔记·stm32·单片机·嵌入式硬件·学习
CV金科1 小时前
蓝桥杯-基于STM32G432RBT6的LCD进阶(LCD界面切换以及高亮显示界面)
c语言·stm32·单片机·嵌入式硬件·蓝桥杯
¥ 多多¥3 小时前
数据结构:内存的使用
linux·c语言·开发语言·数据结构
OidBoy_G4 小时前
EDU 某智慧平台 PersonalDayInOutSchoolData SQL注入漏洞复现
安全·web安全
亿林安全5 小时前
等保测评中的常见误区及应对策略
网络·安全·web安全
亿林网络安全事业部5 小时前
等保测评:企业如何构建安全的网络架构
网络·安全·架构
网络研究院5 小时前
由于安全风险,安全领导者考虑禁止人工智能编码
人工智能·安全·开源·开发·风险·技术·代码
ShenZhenDingYue5 小时前
有毒有害气体检测仪的应用和性能_鼎跃安全
安全·有毒有害气体检测仪·气体检测仪·有毒气体检测·有害气体检测仪·气体检测
咩咩大主教5 小时前
Linux下的简单TCP客户端和服务器
linux·服务器·c语言·开发语言·c++·tcp/ip·网络编程
你不要在理我了6 小时前
weblogic CVE-2018-2894 靶场攻略
运维·服务器·安全