多线程脏读

现象:线程2中的资源初始化依赖于线程1中的资源,在执行效率更高的x86上,模块的执行没有问题,在性能低的单片机上,模块的执行出现了问题

原来业务代码有两个线程,线程1和线程2,线程2中的操作逻辑用到了线程1中初始化的资源,线程1中的资源包括初始化的网卡信息,以及用于通讯的UdpSocket。

原有代码中线程2中使用UdpSocket进行通讯时,并没有等待线程1中的资源初始化完成就进行操作了,原有代码之所以没有发生崩溃,是因为线程2中的UdpSocket大概率不会在线程1没有初始化完成之前进行通讯,所以在线程2使用UdpSocket时,UdpSocket大概率已经完成初始化操作了,且由于使用的是基于POSIX的socket,其出错并不会导致进程崩溃。

但是,我更换了Zmq库,其在Socket传错参数时会回馈Invalid Augment,并且直接抛出错误,导致进程崩溃,我在线程2启动初始化Socket时用到了线程1中初始化的网卡信息,参考先人的代码,我也没加锁。。。。并且在x86上运行一点问题没有,有时候使用gdb在单片机上进行debug时,也不会出错。。。。debug发现线程2进行socket构建时,线程1中的网卡信息获取并没有执行完成,网卡的ip压根就没获取到,导致初始化时的参数就存在问题,加了个用于等待的自旋锁立马就好使了。

想起了当时看csapp上说过的一句话,“多线程时不要假设任何指令的执行顺序”,面对共享资源时一定要考虑临界区的读写问题


不知名电子厂重构屎山的第151天

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值