国庆节在家里面学习了Theron这个高并发的库的使用方法,获益良多。
Theron的官网:http://www.theron-library.com/
最特别的就是Theron 是Actor的模型,而不是object。这一点由于我并非是从JAVA转向的C++语言,所以没有万物皆是对象这个强烈的观点。
一般面向对象的三个特性:组合,继承,和多态。从组合上来说,就是一个class A为了调用class B的方法,需要在class A的定义当中加入一个class B的对象,这是最简单的has-a的方法,但是这样的话如果class A和class B都有锁,一旦组合起来,一不小心容易变成死锁,解决这个问题的方法是使用层级锁。而在Actor模型当中,class A要调用class B的方法不用组合的形式了,而是直接发送一个message来给class B并立即返回,class B收到message之后开始唤醒,和class A并行地执行下去。
这样来看一个actor就可以是一个线程,要启动多个线程直接使用多个actor就可以了,完全拒绝了pthread函数。
为了学习Theron库,我特意重写了测试用例,用Theron来启动多个线程测试DBPool:
这里以gtest_mysql.cpp为例,当然gtest_redis也改动了
#include <iostream>
#include <unistd.h>
#include <stdlib.h>
#include <thread>