Disruptor它是一个开源的并发框架,并获得2011 Duke's 程序框架创新奖,能够在无锁的情况下实现网络的Queue并发操作。
来一个他的例子吧.绝对是hello worl级别的.
只有两个类,一个是执行类,一个是自己定义的类.
自己需要定义一个event类,
package com.trevorbernard.disruptor.examples;
import com.lmax.disruptor.EventFactory;
/**
* WARNING: This is a mutable object which will be recycled by the RingBuffer. You must take a copy of data it holds
* before the framework recycles it.
*/
public final class ValueEvent {
private String value;
public String getValue() {
return value;
}
public void setValue(String value) {
this.value = value;
}
public final static EventFactory<ValueEvent> EVENT_FACTORY = new EventFactory<ValueEvent>() {
public ValueEvent newInstance() {
return new ValueEvent();
}
};
}
这里要用到一个factory类,作用就是生成定义的那个类.
执行类:
package com.trevorbernard.disruptor.examples;
import java.util.UUID;
import java.util.concurrent.ExecutorService;
import java.util.concurrent.Executors;
import com.lmax.disruptor.EventHandler;
import com.lmax.disruptor.RingBuffer;
import com.lmax.disruptor.dsl.Disruptor;
public class Simple {
@SuppressWarnings("unchecked")
public static void main(String[] args) {
ExecutorService exec = Executors.newCachedThreadPool();
// Preallocate RingBuffer with 1024 ValueEvents
Disruptor<ValueEvent> disruptor = new Disruptor<ValueEvent>(ValueEvent.EVENT_FACTORY, 1024, exec);
final EventHandler<ValueEvent> handler = new EventHandler<ValueEvent>() {
// event will eventually be recycled by the Disruptor after it wraps
public void onEvent(final ValueEvent event, final long sequence, final boolean endOfBatch) throws Exception {
System.out.println("Sequence: " + sequence+" ValueEvent: " + event.getValue());
}
};
disruptor.handleEventsWith(handler);
RingBuffer<ValueEvent> ringBuffer = disruptor.start();
for (long i = 10; i < 15; i++) {
String uuid =String.valueOf(i) ;
long seq = ringBuffer.next();
ValueEvent valueEvent = ringBuffer.get(seq);
valueEvent.setValue(uuid);
ringBuffer.publish(seq);
}
disruptor.shutdown();
exec.shutdown();
}
}
设置一个事件的监听,这里只是打印一下.
然后就是把我们定义的事件写入到RingBuffer,然后发布.负责监听的就会接受到.
整个过程是非常的简单的.
附件是源码.
分享到:
相关推荐
java网络技术示例代码,用于初学者学习 多线程,循环buffer,参考博客上的代码,实现内存的读写功能
disruptor-3.3.11.jar 无锁并行框架 值得学习 jar包
disruptor-3.3.11-sources.jar jar包源码,值得学习,源码
Disruptor 简单示例,涵盖多种模型。适合Disruptor 入门学习。
Disruptor原始代码分解析出(超详细注释),版本3.4.2,方便大家阅读源码,供大家学习使用。项目中使用时请从Disruptor官方发布依赖。 ,欢迎指正。 LMAX破坏者 高性能线程间消息传递库 维护者 文献资料 变更日志 ...
Java语言游戏项目实战资源包 内容概览: 这次分享为你带来了丰富的Java语言游戏项目实战资源,让你在实践中深入...持续学习与探索:Java语言和游戏开发技术都在不断更新,建议你在实践中持续学习新的技术和工具,不
}}Disruptor costTime = 7458ms并发编程框架核心讲解2.1 Disruptor-QuickStart-基础元素工厂类Disruptor
使用java开发的游戏项目源码,可用于毕业设计、课程设计、练手学习等
分别有disruptor-3.3.4.jar(Log4j2异步日志的底层实现)、log4j-api-2.19.0.jar(log4j门面)、log4j-core-2.19.0.jar(log4j实现)、log4j-slf4j-impl-2.19.0.jar(SLF4J与Log4j绑定)、slf4j-api-1.7.30.jar(SLF...
java_learning_practice学习java的积累示例:面试高频算法,akka,多线程,zookeeper,Disruptor,NIO,Netty,Thrift等项目组成收集总结初步&&大数据方向看到的优秀文章和系列博客;不定期更新pdf阿卡口味akka学习...
Java敏捷开发平台,采用SpringMVC+Spring+Hibernate+Shiro+ Ehcache+Disruptor+Jquery + Boostrap + Ztree等熟悉框架作为基础架构,大大节约开发学习时间。
基于Disruptor消息队列设计的无锁并发模式 分布式(多进程)架构,几行代码实现一个功能服务器的搭建 多线程设计,注解方式配置,轻松管理所有消息流 强大的RPC功能,调用远程RPC近似于调用本地函数,无需手工定义内部...
,各位开发者可以根据自己的需要改造出更加适合自己的代码生成器,不管是做项目、学习、接私活它都将是你的最佳拍档; JeeWeb主要定位于企业快速开发平台建设,已内置很多优秀的基础功能和高效的 代码生成 工具,...
,各位开发者可以根据自己的需要改造出更加适合自己的代码生成器,不管是做项目、学习、接私活它都将是你的最佳拍档; JeeWeb主要定位于企业快速开发平台建设,已内置很多优秀的基础功能和高效的 代码生成 工具,...
,各位开发者可以根据自己的需要改造出更加适合自己的代码生成器,不管是做项目、学习、接私活它都将是你的最佳拍档; JeeWeb主要定位于企业快速开发平台建设,已内置很多优秀的基础功能和高效的 代码生成 工具,...
,各位开发者可以根据自己的需要改造出更加适合自己的代码生成器,不管是做项目、学习、接私活它都将是你的最佳拍档; JeeWeb主要定位于企业快速开发平台建设,已内置很多优秀的基础功能和高效的 代码生成 工具,...