读muduo网络库笔记(2.8章)

Posted

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了读muduo网络库笔记(2.8章)相关的知识,希望对你有一定的参考价值。

该笔记出自陈硕的《Linux多线程服务端编程》,作者比较注重版权问题,写个读后笔记应该没什么问题吧,如果有,会及时删除,没有的话继续写点笔记

--------------------------------------------

该书在2.8章介绍了copy-on-write的一种做法实例,解决了前文提到的几个需要解决的问题。

第一版本的代码:

技术分享

改版本代码问题在于,如果在Foo::doit中调用了post函数会造成死锁。(不过改bug容易定位)

 

copy-on-write版本代码:

技术分享

技术分享

技术分享

这是正确的写法,下面分析一下作者提供的错误的写法。(自己以前的错误写法就在作者列举的例子中 -。-)

技术分享

错误原因:

错误一是会导致read端在遍历的时候迭代器失效;

错误二是多个线程同时post,会出现某些线程的Foo对象添加失败,因为copy的都是老的g_foos,并且各线程之间并不同步;

错误三导致的结果跟错误二相同,只是错误的姿势不一样。

 

以上是关于读muduo网络库笔记(2.8章)的主要内容,如果未能解决你的问题,请参考以下文章

muduo网络库学习笔记:Reactor模式的关键结构

muduo网络库学习笔记(10):定时器的实现

muduo2.0源码阅读记录

muduo网络库:21---muduo简介之(详解muduo多线程模型)

C++搭建集群聊天室:muduo网络库

C++搭建集群聊天室:muduo网络库