news 2026/4/16 14:03:00

内存越界处理

作者头像

张小明

前端开发工程师

1.2k 24
文章封面图
内存越界处理

一、常见内存越界类型

  • 数组越界写:向数组外写数据,buf[64]写了70字节
  • 栈溢出:局部变量太大或递归太深,定义char large[2KB]在函数内 -->覆盖返回地址
  • 堆溢出:malloc后越界访问,p=malloc(16); p[16]=1;
  • 使用已释放内存:free(p)后继续使用,俗称“野指针”
  • 缓冲区未初始化:读取未赋值内存,导致随机值传给云端
  • 字符串操作越界:strcpy, sprintf不检查长度,经典安全漏洞

二、内存越界解决

1、使能编译器检查

GCC/Clang编译选项:

-fsanitize=address # 地址消毒剂(Linux/X86 可用)

-fsanitize=undefinded # 检查未定义行为

注:Asan在MCU上跑不了,但可用于模拟器测试。

2、手动添加“红区”(Readzone)检测

#define READZONE_VALUE 0xDEADBEEF

typedef struct {

uint32_t redzone_before;

uint8_t data[32];

uint32_t redzone_after;

} safe_buffer_t;

//分配后初始化

safe_buffer_t* buf = malloc(sizeof(safe_buffer_t));

buf->redzone_before = READZONE_VALUE;

buf->redzone_after = READZONE_VALUE;

//使用后检查

if (buf->redzone_after != READZONE_VALUE)

{

printf("ERROR: Buffer overflow detected!\n");

}

适合关键模块(如通信协议解析)

3、使用静态分析工具

PC-link / FlexeLint

Cppcheck

Klockwork / Coverity

4、运行时断言 + 日志

#define CHECK_RANGE(ptr, base, size) \

do { \

if ((uint8_t*)(ptr) < (base) || \

(uint8_t*)(ptr) >= (base) + (size)) { \

log_error("Memory access out of range!"); \

while(1); / * 或触发 Hard Fault */ \

} \

} while(0)

用于访问共享缓冲区时做边界判断。

5、利用硬件功能(MPU / Watchpoint)

在支持MPU的芯片上(如STM32F7/F4):

划分内存区域

设置只读 、不可执行等属性

配置 Data Watchpoint 监视某个地址是否被写入

当越界发生时,触发 HardFault Handler,可以打印调用栈。

综上:修复越界代码 + 加防护机制

三、预防建议

所有字符串操作用 snprintf, strncpy 替代 sprintf, strcpy ------------> 防止栈溢出

关键结构体前后加padding和校验字段 ------------>便于检测破坏

使用固定大小缓冲区代替动态分配 ------------> 减少堆碎片

对接收的数据先验证长度再拷贝 ------------> 特别是网络/MQTT数据

上电自检内存完整性 ------------> 检测Flash/RAM是否损坏

版权声明: 本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若内容造成侵权/违法违规/事实不符,请联系邮箱:809451989@qq.com进行投诉反馈,一经查实,立即删除!
网站建设 2026/4/7 23:05:39

10393_基于SSM的杂志订阅网站管理系统

1、项目包含项目源码、项目文档、数据库脚本、软件工具等资料&#xff1b;带你从零开始部署运行本套系统。2、项目介绍该文主要讲述了数字杂志网站的设计过程与实现结果。系统将运用Eclipse开发工具构建开发环境&#xff0c;用Java语句实现&#xff0c;节约环境配置时间&#x…

作者头像 李华
网站建设 2026/4/16 3:39:47

【压力】矩阵-断裂-瓦格压力瞬态曲线模型和类型曲线附Matlab代码

✅作者简介&#xff1a;热爱科研的Matlab仿真开发者&#xff0c;擅长数据处理、建模仿真、程序设计、完整代码获取、论文复现及科研仿真。&#x1f34e; 往期回顾关注个人主页&#xff1a;Matlab科研工作室&#x1f34a;个人信条&#xff1a;格物致知,完整Matlab代码获取及仿真…

作者头像 李华
网站建设 2026/4/16 12:26:51

学网络安全的,一定要避开这些坑!

网络安全学习的误区 1.不要试图以编程为基础去学习网络安全 不要以编程为基础再开始学习网络安全&#xff0c;一般来说&#xff0c;学习编程不但学习周期长&#xff0c;且过渡到网络安全用到编程的用到的编程的关键点不多。一般人如果想要把编程学好再开始学习网络安全往往需要…

作者头像 李华
网站建设 2026/4/13 6:08:52

前端——TailwindCSS在管理系统中的应用技巧

TailwindCSS作为一个功能类优先的CSS框架&#xff0c;在后台管理系统中有独特的优势。 1 响应式布局 <!-- 响应式网格布局 --> <div class"grid grid-cols-1 md:grid-cols-2 lg:grid-cols-3 gap-4"><div class"bg-white rounded-lg shadow p-6&q…

作者头像 李华
网站建设 2026/4/12 15:39:21

盲盒小程序开发✨全玩法覆盖不踩坑!

盲盒小程序开发✨全玩法覆盖不踩坑&#xff01;做盲盒小程序怕玩法单一&#xff1f;我们全搞定&#xff01;&#x1f389;爬塔闯关赢稀有赏、经典一番赏抽限定款、无限赏解锁持续惊喜&#xff0c;还有对对碰互动 PK&#xff0c;玩家粘性直接拉满&#xff01;社交 商城双 buff …

作者头像 李华