Linux多线程服务端编程知识点总结
重点讲解多线程网络服务器的一种IO模型,即one loop per thread。以muduo网络库为例,讲解这种模型的编程方法及注意事项。
muduo是一个基于非阻塞IO和事件驱动的现代C++网络库。
第一部分 C++多线程系统编程
线程安全的对象生命周期,编写线程安全的类,用同步原语保护内部状态即可。
当一个对象被多个线程同时看到时,那么对象的销毁时机就会变得模糊不清,可能出现多种竞态条件。对象构造要做到线程安全,唯一的要求是在构造期间不要泄露this指针。
神器shared_ptr/weak_ptr shared_ptr是引用计数型智能指针。引用计数是自动化资源管理的常用手段,当引用计数降为0时,对象即被销毁。weak_ptr也是一个引用计数应智能指针,但它不增加对象的引用次数,即弱(weak)引用。shared_ptr控制对象的生命期,weak_ptr不控制对象的生命期。内存泄露(借了东西不归还),用scoped_ptr,对象析构时自动释放内存。