Java协程开源库---kilim

Kilim协程框架图
请添加图片描述

Task

Task对象是Kilim中核心的结构,所有业务的逻辑代码都是在Task中执行。

Scheduler

Scheduler是Kilim框架中核心的任务调度器,负责管理任务的工作者线程WorkerThread,以及一个基本的FIFO队列,维护着 Task任务列表,Scheduler负责分派Task给指定的工作者线程WorkerThread执行。

WorkerThread

WorkerThread是执行任务Task的具体线程,内部维护一个默认大小为10的环形队列RingQueue

RingQueue

RingQueue本质上即一个环形队列,作为Queue用于不同的线程之间传递message的设计

Mailbox

Kilim 中通过Mailbox 对象来发送消息,Mailbox 的基本原则为可以有多个消息发送者,但只能有一个消息接收者,发送的方式有同步发送、异步发送和阻塞线程方式的同步发送三种:

  • 同步发送是指保证一定能将消息放入发送队列中,如当前发送队列已满,则等待到可用为止,阻塞的为当前Task;
  • 异步发送则是尝试将消息放入发送队列一次,如果发送失败,则返回false,成功则返回true,不会阻塞Task;
  • 阻塞线程方式的同步发送是指阻塞当前线程,并保证将消息发送给接收者。

Fiber

Kilim中的Fiber对象主要用来维护Task执行过程中的堆栈

  • 利用字节码技术(基于ASM字节码框架),将普通代码转化为支持协程的代码;
  • 调用Pauseable方法的时候,如果方法暂停了就保存当前方法的堆栈,暂停执行当前Task,将控制权交给Scheduler调度器;
  • Scheduler调度器负责协调其他就绪的Task;
  • 之前暂停的Task恢复的时候,自动恢复对应方法的堆栈,恢复到上次执行的位置继续执行;
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值