百度brpc初步分析

本文简要探讨了百度的brpc,对其文档质量表示赞赏,但指出`RunUntilAskedToQuit()`方法可能浪费线程资源,以及`Server::StartInternal`中的线程管理设计存在不足。同时,提到brpc和corelooper在某些功能上有相似之处,并预告corelooper的开源计划。

最近在QQ群听说百度的brpc非常好,所以下载研究一下。

首先,它的文档写的非常用心,要点个赞。

里面有个brpc_intro.pptx用搞笑且浅显易懂的方式来做介绍,非常合我心意。

闲话少说,下面转入正题。

brpc代码量有点大,没时间细看,粗略看了一下代码,感觉有些地方有改进空间。

下面描述一下

大量代码在int main()中调用了

server.RunUntilAskedToQuit()

它的实现如下

void Server::RunUntilAskedToQuit() {
    while (!IsAskedToQuit()) {
        bthread_usleep(1000000L);
    }
    Stop(0/*not used now*/);
    Join();
}
这实际上相当于浪费了一个线程来做无意义的事,此处差评

然后看Server::StartInternal,从下面这段红色代码可以感觉出对线程的用法设计有缺陷,至少是没那么完善

        // Wait until all created bthreads finish the init function.
        for (size_t i = 0; i < ncreated; ++i) {
            while (!init_args[i].done) {
                bthrea

评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值