news 2026/6/10 10:47:56

内存越界处理

作者头像

张小明

前端开发工程师

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/6/10 2:49:58

从关系型数据库到时序数据库的思维转变

一、核心范式转变&#xff1a;从“实体关系”到“时间流事件” 维度关系型数据库 (RDBMS)时序数据库 (TSDB)核心抽象​实体与关系。世界由“学生”、“订单”、“产品”等实体构成&#xff0c;通过外键关联。带时间戳的测量流。世界是持续变化的“指标”&#xff0c;如“CPU温…

作者头像 李华
网站建设 2026/6/7 5:37:05

拿一句 “油腻情话”,把你家男人甜到起鸡皮疙瘩

1️⃣ 你能帮我递个东西吗&#xff1f;递什么&#xff1f;递我的真心给你呀&#xff5e;2️⃣ 你是属磁铁的吧&#xff1f;不然我怎么老想黏着你&#xff01;3️⃣ 今天喝了杯奶茶&#xff0c;什么茶&#xff1f;想你想到茶不思饭不想&#xff5e;4️⃣ 我最近在练一项技能&…

作者头像 李华
网站建设 2026/6/6 0:40:39

AI产品经理转型+大模型实战:收藏这套系统化学习资源,小白也能变专家

文章介绍AI产品经理职责、与传统产品经理的区别(需懂技术)、类型分类及必备技能&#xff0c;重点分享AI大模型学习资源&#xff0c;包括七阶段学习路线、300视频教程、数百本技术文档和面试题&#xff0c;帮助小白和程序员系统掌握大模型应用开发技能。1.AI产品经理是什么 回答…

作者头像 李华
网站建设 2026/6/7 20:02:22

基于Vue的电商后台管理系统的设计与实现qyf0i(程序 + 源码 + 数据库 + 调试部署 + 开发环境配置),配套论文文档字数达万字以上,文末可获取,系统界面展示置于文末

系统程序文件列表 系统功能 用户,商品分类,品牌信息,商家,商品信息,促销商品,咨询商家 开题报告内容 《基于Vue的电商后台管理系统的设计与实现》开题报告 一、选题背景、研究意义及国内外研究现状 1. 选题背景 随着互联网技术的快速发展和数字化转型的深入推进&#xff0…

作者头像 李华
网站建设 2026/6/9 14:08:34

RK3568 Android14 集成 HYM8563 外部 RTC (I2C接口)

RK3568 Android14 集成 HYM8563 外部 RTC (I2C接口) 前言 虽然 RK3568 SoC 内部自带了 RTC 控制器&#xff08;rtc-rkw808&#xff09;&#xff0c;但在很多工业板卡或手持设备设计中&#xff0c;为了更低的待机功耗和更灵活的电池备份方案&#xff0c;硬件工程师往往会选择外挂…

作者头像 李华