Java协程开源库---kilim

Kilim协程框架图
Java协程开源库---kilim_第1张图片

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恢复的时候,自动恢复对应方法的堆栈,恢复到上次执行的位置继续执行;

你可能感兴趣的:(java基础,java,开发语言)