官方github
https://github.com/chriskohlhoff/asiogithub.com我看的例子是这个目录下的
/asio/src/examples/cpp11/echo/async_tcp_echo_server.cpp
如果你想在linux下编译asio库,需要在cmake加如下代码
set(CMAKE_CXX_FLAGS "${CMAKE_CXX_FLAGS} -pthread")
或者直接编译
g++ test.c -o test -lpthread
问题原因:
pthread 库不是 Linux 系统默认的库,链接(编译的一个步骤)时需要使用静态库 libpthread.a,所以在使用pthread_create()创建线程以及调用 pthread_atfork()函数建立fork处理程序时,需要链接该库
POSIX就是一个标准
POSIX表示可移植操作系统接口(Portable Operating System Interface of UNIX,缩写为 POSIX ),POSIX标准定义了操作系统应该为应用程序提供的接口标准,是IEEE为要在各种UNIX操作系统上运行的软件而定义的一系列API标准的总称
比如POSIX Threads 或 Pthreads 提供的 API 可在多种类 Unix POSIX 系统上使用,比如 FreeBSD、NetBSD、GNU/Linux、Mac OS X 和 Solaris
常见posix API
pthread_create():创建一个线程
pthread_exit():终止当前线程
pthread_cancel():中断另外一个线程的运行
pthread_join():阻塞当前的线程,直到另外一个线程运行结束
pthread_attr_init():初始化线程的属性
pthread_attr_setdetachstate():设置脱离状态的属性(决定这个线程在终止时是否可以被结合)
pthread_attr_getdetachstate():获取脱离状态的属性
pthread_attr_destroy():删除线程的属性
pthread_kill():向线程发送一个信号
如果想让自己的代码在posix平台上保持兼容,请使用上述API 而不要使用linux特有的如clone这样的API
代码注释:
不想飞的猪:boost::asio入门学习 简单服务器async_tcp_echo_server.cpp注释zhuanlan.zhihu.com刚连接
按道理在std::make_shared<Session>(std::move(socket))作用域超出的时候就会调用~Session, 但为什么没调用析构函数, 这就是auto self(shared_from_this());的作用,使用它并不会使引用自加一, 但是它可以延长对象生命周期
发个信息可以看出此时self.use_count()=1.,引用计数为一,当然不会被析构
简单分析一下 asio::async_read_some和asio::async_write两个函数的一下行为
有信息发过来,async_readsome调用lambda, lambda调用do_write(length) 然后async_readsome函数结束,
被调用的do_write等待, 当有信息需要发送,它里面的函数async_write调用lambda, 然后lambda调用do_read(), 然后此async_write结束,
(说了好多废话,哈哈)
有点像 A()函数里调用了B()函数, B()函数又调用了A()的感觉, 但并不一样, 而且很不一样,前者调用后人家会自动释放(函数结束了),但是后者, ...貌似一直嵌套........消耗资源
断开连接, Session析构