1
0
mirror of https://github.com/tearshark/librf.git synced 2024-10-01 15:57:07 +08:00
librf/README.md

38 lines
2.0 KiB
Markdown
Raw Normal View History

2020-03-18 21:46:55 +08:00
# librf 2.8
2017-09-24 14:01:30 +08:00
### librf - 协程库
2020-03-18 21:46:55 +08:00
2020-03-18 更新:
更新event/mutex/when_all/when_any实现。至此2.x版本完整恢复1.x版本的所有功能。
版本号提升至 2.8.0。
3.0之前只打算做修复BUG相关的工作。
3.0的目标是根据executor的设计重写scheduler代码。
2020-03-09 14:23:35 +08:00
2020-03-08 更新:
更新channel实现效率提高了近三倍。
channel的新的实现方法为event/mutex指明了新的修改方向。
2020-02-16 01:23:52 +08:00
2020-02-16 更新:
更新调度器算法深入应用Coroutines的特性以期获得更高调度性能。
不再支持C++14。
2020-02-16 15:06:09 +08:00
librf是一个基于C++ Coroutines提案 Stackless Resumable Functions编写的非对称stackless协程库。
2017-09-24 14:01:30 +08:00
目前仅支持:
2020-03-18 21:46:55 +08:00
Windows (使用VS2017/VS2019/clang 9编译)
Android (使用NDK 20.1 自带的clang编译)
2017-09-24 14:01:30 +08:00
librf有以下特点
2020-03-18 21:46:55 +08:00
* 1.基于C++20提案'Stackless Resumable Functions'编写的非对称stackless协程库可以以同步的方式编写简单的代码同时获得异步的性能
* 2.理论上支持海量协程, 创建1000万个协程只需使用<2.2G>物理内存(使用clang编译)
2020-03-18 21:59:36 +08:00
* 3.拥有极小的协程调度在I7 8100 3.6GHz的CPU上1000个协程的平均切换开销是27纳秒(使用clang编译)
2020-03-18 21:46:55 +08:00
* 4.提供协程锁(mutex), 定时器, channel, event等特性, 帮助用户更加容易地编写程序
* 5.可以很好的跟asio, libuv等库结合能跟现有的callback范式的异步/延迟代码很好的结合
* 6.目前已处于较为完善状态已经小规模在生产项目中使用。不出意外2.8以上版本就是C++20 Coroutines对应的版本
2019-04-21 09:05:04 +08:00
2017-09-24 14:01:30 +08:00
* 如果你发现了任何bug、有好的建议、或使用上有不明之处可以提交到issue也可以直接联系作者:
email: tearshark@163.net QQ交流群: 296561497
* **doc目录下有作者搜集的一些关于C++协程的资料**
* **tutorial目录下有针对每个特性的范例代码让用户可以循序渐进的了解librf库的特性**