最近调查线上一个问题,就是一块 int32 的内存会极低概率出现 -18亿的巨数字,有时又是正确的。自己刻意测试又不能再现,在确认不可能将这样一个巨量数字写入的情况下,这时只能怀疑多线程并发在作祟了(其实,在任何时候出现低概率事件又无法解释的时候,怀疑是多线程并发导致的,往往是非常不错的方向)。
在调查写入内存可能的地方时,发现有一个 memcpy() 函数拷贝数据的地方,而其他有的地方用的直接是int赋值或int指针赋值就不会出现数据错乱的情况。根据各种情况判断下来,一定就是 memcpy() 在多线程拷贝的时候,不是原子性的,是一个个字节进行拷贝,就会出现内存写入非预期的值的情况。而赋值是原子性的,可以无需加锁。
解决方法嘛,当然是加锁了,可以使用mutex互斥锁,但是考虑到高性能因素,使用spinlock自旋锁可能比较好,也可以考虑使用CAS的方式进行内存原子拷贝。
memcpy() 是非线程安全的,并发时需加锁或使用原子操作
来源:清泛原创 2023-04-05 16:13:56 人气: 我有话说( 0 人参与)
最近调查线上一个问题,就是一块 int32 的内存会极低概率出现 -18亿的巨数字,有时又是正确的。自己刻意测试又不能再现,在确认不可能将这样一个巨量数字写入的情况下,这时只
上一篇:【解决】undefined reference to 'apr_thread_rwlock_destory'、undefined reference to 'apr_initialize'
下一篇:C++ SpinLock 自旋锁的代码实现(全网最简略的方式)
注:本文为本站或本站会员原创优质内容,版权属于原作者及清泛网所有,
欢迎转载,转载时须注明版权并添加来源链接,谢谢合作! (编辑:admin)
欢迎转载,转载时须注明版权并添加来源链接,谢谢合作! (编辑:admin)
相关热点
- 1google mock分享(全网最全最好的gmock文...
- 2【解决】asan runtime does not come ...
- 3MFC学习总结 (90个技巧) dlg 上建立View
- 4coinitialize失败,返回值是0x80010106 无...
- 5VS Addin插件基本开发入门
- 6use of deleted function std::unique_...
- 7浅析Linux段错误:SEGV_MAPERR、SEGV_ACCERR
- 8hidden symbol ... is referenced by DSO 剖析
- 9c++编译错误:invalid new-expression of abstract class type
- 10Reference to ' ' is ambiguous:符号定义重复
本月排行
- 1google mock分享(全网最全最... 165次浏览
- 2【解决】asan runtime does... 108次浏览
- 3浅析Linux段错误:SEGV_MAPERR、SEGV_ACCERR 66次浏览
- 4MFC学习总结 (90个技巧) dlg 上建立View 50次浏览
- 5【解决】munmap_chunk(): invalid pointer 44次浏览
- 6hidden symbol ... is referenced by DSO 剖析 43次浏览
- 7Reference to ' ' is ambi... 41次浏览
- 8coinitialize失败,返回值是0x8... 29次浏览
- 9gcc自带内存泄漏、内存越界检测... 28次浏览
- 10jemalloc 接入方法:提高内存... 22次浏览
评论排行
- 1C++ 读写xml方法整理(持续更新)3次评论
- 2Reference to ' ' is ambiguous:符号定义重复2次评论
- 3全民OS2次评论
- 4__attribute__2次评论
- 5海量数据相似度计算之simhash和海...2次评论
- 6C++使用OLE/COM高速读写EXCEL的源码2次评论
- 7AfxIsValidAddress 测试内存地址2次评论
- 8C++入门进阶最佳实战2次评论
- 9phpcms附件上传 Flash换成H52次评论
- 10解决xrdp登陆不上的问题:xrdp s...2次评论