phxrpc简介
phxrpc是微信开源的轻量级rpc框架,支持协程模式,代码量不大,很适合拿来学习一个。
定制输入输出流
phxrpc使用标准输入输出的方式封装了socket,使用<<
和>>
来实现读写。
实现类图如下:
streambuf
streambuf
是一个流缓冲区,包含输入和输出缓冲区。向ostream
写入时,数据会放到输出缓冲区中,从istream
读取时,数据从输入缓冲区中读出。
streambuf输出缓冲区
输出缓冲区由三个指针维护,pbase
指向起始位置,epptr
指向末尾(类似迭代器,前闭后开),pptr
指向当前可放置的位置。向输出缓冲区写入数据的函数是sputc
和sputn
,第一个写入一个字符并将pptr
向后移动一位。第二个写入多个字符。当缓冲区满时,会调用overflow()
函数将所有数据发送并清空缓冲区,调用pbump(0)
重置pptr指针到起始位置。
int BaseTcpStreamBuf::sync() {
//缓冲区已满,将数据发送
int sent = 0;
int total = pptr() - pbase();
while (</