码迷,mamicode.com
首页 > 其他好文 > 详细

程序崩溃调试记录和总结

时间:2016-04-08 11:45:23      阅读:145      评论:0      收藏:0      [点我收藏+]

标签:

1. 多线程访问共享资源没有加锁

错误提示:Segmentation fault!
解决办法:

  • 多线程读不需要加锁
  • 多线程同时读写则需要加锁
    加锁的方法有互斥量、信号量、读写锁、记录锁、互斥量和条件变量结合提供的事件通知机制。
    C++11里则有,lock_guard,unique_lock.两者都是在构造的时候加锁,析构的时候加锁。但unique_lock提供更多的特性,比如可以指定它在构造的时候不加锁,在需要的时候再调用.lock()加锁。如果和condition_variable结合使用只能用unqiue_lock.

2. 指针变量在定义的时候没有初始化为nullptr,或者在某个时候执行变成了悬挂指针,导致不可预知的错误。

错误提示:Segmentaion fault!
解决方法:

  • 指针变量在声明的时候初始化为nullptr,在使用的时候判断if(!ptr)
  • 仔细检查代码,杜绝出现悬挂指针。

3. std::thread在joinalble状态下析构会导致terminate

错误提示::terminate called without an active exception. Aborted
解决办法:

  • 创建thread的时候调用detach使之变为分离线程
  • thread执行之后调用join等待thread正常结束
    但是在写代码量多了之后,有时候会在甘个代码分支过早退出而引起thread析构而没运行到join语句,这样就会导致terminate;
    示例代码如下:
  1. void foo()
  2. {
  3. //do something;
  4. }
  5. int main()
  6. {
  7. std::thread t(foo);
  8. if(true)return1;
  9. t.join();
  10. return0;
  11. }

代码8时t以foo构造并运行,此是为joinable状态,代码9时程序退出,导致t在t.join()之前析构,thread在joinable状态析构下会导致terminate。~thread函数在cplusplus说明如下:
If the thread is joinable when destroyed, terminate() is called.





程序崩溃调试记录和总结

标签:

原文地址:http://www.cnblogs.com/arhlong/p/5367255.html

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!