libuv抽象接口简单梳理

libuv抽象接口简单梳理

抽象类型

libuv虽然看起来代码没有几行,但是初略过了下文件,功能非常丰富,至少比boost.asio功能要多得多,当前只分析几个基础类型和网络相关的类型。

UVErrorCode

用于封装libuv体系下的错误码,可以采用类似boost::error_code的技法来实现

UVHandle

用于抽象句柄,libuv大部分类型都从这里派生。定义了一些基础但是通用的成员函数指针,让派生类扩展。

  • uv_handle_type: 保存实际的handle类型
  • uv_alloc_cb: 提供给uv_read_start等读操作使用的,内存池接口,释放由读回调方完成。
  • uv_close_cb: 句柄的关闭回调,利用这个特性比较容易实现内存管理,还不确定线程安全性,大概率在loop中执行
    比较好玩的是提供了一组这样的API:
  • uv_is_closing
  • uv_ref
  • uv_unref
  • uv_has_ref
    xx_ref的一组API并不是用来做引用计数的内存管理,而是标记flag和给托管的loop添加active_handles

AsyncHandle

异步句柄,绑定一个回调,每次通过uv_async_send会唤醒一次回调

«temapte THandle»
UVHandle
THandle* _uv_handle; // 模板类型,类似之智能指针技法,最后根据类型释放
bool _need_close; // 析构时是否需要关闭句柄
UVHandle()
UVHandle(UVHandle&& other)
UVHandle& operator =(UVHandle&& other)
UVHandle(UVHandle&)
UVHandle& operator =(const UVHandle&)
THandler* get()
bool is_active()
void close(callback_t callback = nullptr)
UVErrorCode
int _errcode;
AsyncHandle
-EventLoop _loop;
AsyncHandle(EventLoop& loop, UVCallback cb)
UVErrorCode send()
EventLoop
std::thread _loop_thread;
uv_loop_t* _uv_loop;
Async* _async_handle;
std::atomic _status;
+int run()
+int run_no_wait()
+int stop()
+bool is_stopped()
+bool is_run_in_loop_thread()
+void run_in_this_loop()
+handle get_native_handle()
+uv_loop_t* handle()
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 1
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值