资讯专栏INFORMATION COLUMN

【JAVA新生】kilim版的协程

Barry_Ng / 1318人阅读

摘要:试用了一下,发现它是基于的主要是。于是拿的代码改了一个纯协程的版本出来。两个都是以提供和为主要,把协程的隐藏在下面。为了搞一个更简单的,纯协程来玩,把里无关的代码都给删了。结果在这里和官方的版本的不同在于,添加了一个方法相当于的。

试用了一下 http://docs.paralleluniverse.co/quasar/,发现它是基于JDK 1.7的(主要是fork join pool)。于是拿kilim的代码改了一个纯协程的版本出来。kilim的原始版本(https://github.com/kilim/kilim)里所有的Task都与一个Scheduler绑定,而且官方的例子里都是讲怎么使用Mailbox做messaging的。这个路数和stackless python非常像。两个都是以提供scheduler和messaging为主要api,把协程的api隐藏在下面。为了搞一个更简单的,纯协程api来玩,把kilim里无关的代码都给删了。结果在这里:https://github.com/taowen/kilim

和官方的版本的不同在于,Task添加了一个方法resume(相当于greenlet的switch)。第一次执行resume的时候就是开始执行这个task。如果task yield了,就会中途退出。要在断点继续的话,再次调用resume。

package hello_world;

import kilim.Pausable;
import kilim.Task;

public class Main {

    public static void main(String[] args) {
        Task task = new Task() {
            @Override
            public void execute() throws Pausable {
                System.out.println("hello");
                yield();
                System.out.println("world");
            }
        };
        task.resume();
        System.out.println("hey there");
        task.resume();
    }

}

代码输出如下

hello
hey there
world

要想执行的话。要预先进行weave。其实就是一条命令java kilim.tools.Weaver -d classesDir classesDir。但是要把这条命令整合到gradle的build过程中,还是很不容易的

apply plugin: "java"
apply plugin: "application"

mainClassName = "hello_world.Main"

repositories {
    mavenCentral()
    mavenLocal()
}

configurations {
    kilim
}

dependencies {
    compile "org.slf4j:slf4j-api:1.7.5"
    compile "org.github.taowen:kilim:1.0"
    kilim "org.github.taowen:kilim:1.0"
    testCompile "junit:junit:4.11"
}

task weave(type: JavaExec) {
    classpath "$project.buildDir/classes/main"
    classpath configurations.kilim
    main = "kilim.tools.Weaver"
    args "-d", "$project.buildDir/classes/main", "$project.buildDir/classes/main"
}

classes.dependsOn(weave)

关键点在于classes.dependsOn(weave),这样可以让weave在javaCompile之后,classes之前执行。这种修改别的task的dependency的做法比ANT灵活多了。

文章版权归作者所有,未经允许请勿转载,若此文章存在违规行为,您可以联系管理员删除。

转载请注明本文地址:https://www.ucloud.cn/yun/64157.html

相关文章

  • JAVA新生】echo server的第n种写法

    摘要:基本上所有的网络应用都会示范一个的写法。除了这些操作的主体是而不是,操作的是,而不是。以为例其过程是这样的这段代码就是创建一个,并注册一个,并把附着到上。关键之一显然是利用了协程的和,把回调转换成顺序的逻辑执行。 基本上所有的网络应用都会示范一个tcp的echo写法。前面我们已经看到了如何使用协程和异步io来做tcp服务器的第一步,accept。下面是一个完整的echo server的...

    Luosunce 评论0 收藏0
  • 协程原理】 - 为什么greenlet的状态无法被保存

    摘要:特别是最火的协程框架也无法保存状态,让人非常惋惜。但是因为栈的本身无法持久化,所以也就无法持久化。其难度在于,假设整个要持久化的调用栈全部都是内的,比如纯的。采取的是暴力地把整个栈区域拷贝到上的方式来保存其状态。 python主流的协程实现有五种: cPython的generator cPython的greenlet cPython的fibers stackless python ...

    verano 评论0 收藏0
  • 协程原理】 - Java中的协程

    摘要:很长一段时间,我都很天真的认为,特别是以为代表的库,才是协程的乐土。里是没法实现协程,更别说实现这样可以的协程的。咱真的是太井底之蛙了。不完全列表如下还有一个据作者说是最的这些协程库的实现方式都是类似的,都是通过字节码生成达到的目的。 很长一段时间,我都很天真的认为python,特别是以gevent为代表的库,才是协程的乐土。Java里是没法实现协程,更别说实现stackless py...

    dongfangyiyu 评论0 收藏0
  • 次时代Java编程(一) Java里的协程 | 出续篇 更新ed

    摘要:所以系统的吞吐能力取决于每个线程的操作耗时。另外过多的线程,也会带来更多的开销。其代表派是以及里的新秀。类似线程也有自己的栈。线程中断的条件只有两个,一个是抛异常,另外一个就是。 什么是协程(coroutine) 这东西其实有很多名词,比如有的人喜欢称为纤程(Fiber),或者绿色线程(GreenThread)。其实最直观的解释可以定义为线程的线程。有点拗口,但本质上就是这样。 我...

    gecko23 评论0 收藏0
  • JAVA新生】拿协程开始写个异步io应用

    摘要:接下来,就看怎么用协程来实现异步了。直接拿的原始写代码会死人的。引入协程就是为了把上下连续的业务逻辑放在一个协程里,把与业务关系不大的的处理部分放到框架的里。第三部分是放弃掉执行权。这样一个只能接收打印一行的异步应用就写好了。 前面已经准备好了greenlet对应的Java版本了,一个删减后的kilim(http://segmentfault.com/blog/taowen/11900...

    singerye 评论0 收藏0

发表评论

0条评论

最新活动
阅读需要支付1元查看
<