内存越界引起的bug汇总

本文总结了五个因内存越界导致的编程问题,包括:1) 内存越界引起的死锁;2) 内核栈溢出导致的panic;3) 结构体强转误操作指针;4) cache pool释放问题;5) 变量越界产生的错误。这些问题提醒开发者在编程时要特别注意内存管理,避免类似错误的发生。
摘要由CSDN通过智能技术生成

1

一个比较隐蔽的死锁bug

 

在测试代码的过程中,发现有大概百分之一的概率会出现一个死锁bug。进过仔细检查,发现加锁,解锁的地方是没有问题的。实在找不到问题的原因了,一狠心在每次加锁和解锁之后,将rwlock_t中的lock值打印出来。 每次write_unlock之后,那个值本应该是0的,但在出现问题的时候,发现那个值一个乱码。于是怀疑是锁占的那块内存被写掉了(内存越界)。后来调试发现, 由于在结构体中 rwlock_t 是放在最后的位置上的,它前面还有个字符数组,由于往字符数组里写东西的时候,没有强制长度(写的随机数)。因此发生由于内存越界导致的死锁。

 

2

内核栈溢出引起的bug 

现象:

在内核schedule函数里面发生panic,提示schedule处于原子上下文中(in_atomic()为1 ,即当前thread_info的preempt_count不为0)。进过加log调试发现,preempt_count是突然变成一个很大的数的。 


这种现象比较容易重复,提示的panic信息也相同。


猜测:

是内核栈溢出。 因为内核栈和thread_info共用8k的内存,因为内

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值