`
raymond.chen
  • 浏览: 1441265 次
  • 性别: Icon_minigender_1
  • 来自: 广州
社区版块
存档分类
最新评论

LongAdder和LongAccumulator的使用

 
阅读更多

LongAdder是jdk1.8提供的累加器,基于Striped64实现。它常用于状态采集、统计等场景。AtomicLong也可以用于这种场景,但在线程竞争激烈的情况下,LongAdder要比AtomicLong拥有更高的吞吐量,但会耗费更多的内存空间。

 

LongAccumulator和LongAdder类似,也基于Striped64实现。但要比LongAdder更加灵活(要传入一个函数式接口),LongAdder相当于是LongAccumulator的一种特例。

 

private static ExecutorService service;

//从初始值0开始,做加/减处理,每次加/减1
private static LongAdder adder = new LongAdder();

//从初始值0开始,做累加处理
private static LongAccumulator accumulator1 = new LongAccumulator((x, y) -> x+y, 0);

//从初始值1开始,做累积处理
private static LongAccumulator accumulator2 = new LongAccumulator((x, y) -> x*y, 1);

public static void main(String[] args) {
	service = Executors.newCachedThreadPool();
	
	for(int i=0; i<10; i++){
		service.submit(() -> {
			adder.increment(); //加1
//			adder.decrement(); //减1
			System.out.println(adder.intValue());
			
			accumulator1.accumulate(2); //每次加2
			System.out.println(accumulator1.get()); //获取当前值

			accumulator2.accumulate(2); //每次 * 2
			System.out.println(accumulator2.get()); //获取当前值
			
		});
	}
	
	service.shutdown();
}

 

 

分享到:
评论

相关推荐

    Java并发工具类LongAdder原理实例解析

    * 高性能:LongAdder的性能优于AtomicLong,这是因为LongAdder使用了惰性加载的机制和动态的Cells数组大小。 * 低争夺共享资源的并发量:LongAdder将一个变量分解为多个变量,让同样多的线程去竞争多个资源,从而...

    java多线程自增效率比较及原理解析

    **效率分析**: `LongAccumulator`的并发性能介于`AtomicInteger`和`LongAdder`之间,但在特定场景下(比如自定义累加逻辑)可能更具优势。 #### 三、实验对比 为了直观展示上述不同方法在多线程环境下的性能差异,...

    JDK8中新增的原子性操作类LongAdder详解

    LongAdder的使用场景非常广泛,例如,在高并发的环境中,需要对某个变量进行原子性递增或递减操作时,就可以使用LongAdder。 LongAdder也可以用来实现分布式锁、计数器、统计数据等等。 LongAdder是JDK8中新增的...

    Java并发编程包中atomic的实现原理示例详解

    在Java 8中引入了四个新的计数器类型,LongAdder、LongAccumulator、DoubleAdder、DoubleAccumulator。他们都是继承于Striped64。LongAdder与AtomicLong的区别是,LongAdder引入了分段锁的概念,可以根据当前线程...

    java8的DoubleAccumulator使用.docx

    随着 Java 8 的发布,引入了一系列新的并发工具类,其中就包括 `DoubleAccumulator`、`DoubleAdder`、`LongAccumulator` 和 `LongAdder`。这些类旨在解决在多线程环境下对浮点数和整数进行原子性操作的问题,特别是...

    LongAdder源码解读

    通过对代码的流程分析,一步一步拆解,将源码解读变得简单

    不同并发场景下LongAdder与AtomicLong如何选择.zip

    计算机技术、IT咨询、人工智能AI理论介绍,学习参考资料计算机技术、IT咨询、人工智能AI理论介绍,学习参考资料计算机技术、IT咨询、人工智能AI理论介绍,学习参考资料计算机技术、IT咨询、人工智能AI理论介绍,学习...

    Java高并发实战_java高并发_高并发_

    第6章介绍了 Java 8中为并行计算做的新的改进, 包括并行流、 CompletableFuture、 StampedLock和LongAdder。第7章主要介绍了高并发框架Akka的基本使用方法,并使用Ak:ka框架实现了 个简单的粒子群算法, 模拟超高...

    多线程并发技术

    在实践中,比如在"实战Java高并发程序设计"课程中,讲师会通过具体的案例分析和代码实战来讲解如何使用这些并发编程的新特性来解决实际问题。这个课程会教授学生如何编写高效的并发代码,如何进行并发调试,以及如何...

    jdk8-win-64位.rar

    7. **新的数值类型**:引入了LongAdder和DoubleAdder,它们在多线程环境下提供了更好的性能,比传统的AtomicLong和AtomicDouble更适合高并发计数场景。 8. **改进的类型推断**:JDK8增强了编译器的类型推断能力,...

    Java Atomic类及线程同步新机制原理解析

    这是因为Atomic类和LongAdder使用CAS操作来实现原子操作,而synchronized关键字会引入锁机制,导致性能下降。 结论 在Java并发编程中,Atomic类是一种非常有用的机制,用于实现原子操作和线程同步。Atomic类使用...

    无锁队列Disruptor超详细教程

    Java 8引入了LongAdder和Striped64类,它们利用Cell元素来消除伪共享,提高并发性能。 ### 2. Disruptor的使用实战 #### (1) 定义Event和工厂 Disruptor的运作基于Event,开发者需要定义Event类以存储传递的数据。...

    jdk1.8.rar

    8. **并发改进**:包括Fork/Join框架的优化,更高效的并发数据结构,如LongAdder和DoubleAdder,以及改进的并发工具类。 9. **String和StringBuilder优化**:新增了一些方法,如`join()`和`repeat()`,使得字符串...

    解压版OpenJDK8_x64_Win_jdk8u172-b11.zip

    8. **新的数值类**:Java 8还添加了新的数值类,如LongAdder和DoubleAdder,它们在多线程环境下提供了更好的性能。 9. **并行数组操作**:Arrays类增加了新的并行处理方法,如parallelSort(),可以在多核处理器上...

    Disruptor应用实例

    通过使用LongAdder等无锁算法,Disruptor避免了传统锁机制带来的性能瓶颈。此外,它采用Sequence机制,确保了生产者与消费者之间的顺序一致性,避免了数据竞争。 2. **环形缓冲区的工作流程** 生产者通过一个叫做...

    官方java8规范-jls8.rar

    Java 8还引入了新的数值类型:`LongAdder`和`DoubleAdder`,它们在高并发环境下提供更好的性能。相比于传统的`AtomicInteger`和`AtomicLong`,这些类在多线程累加操作中具有更低的竞态条件开销。 总的来说,Java 8...

    JDK8 中文帮助文档(jdk api 1.8 google.CHM)

    JDK8对并发库也进行了增强,如`ConcurrentHashMap`的改进,新增`AtomicIntegerArray`、`LongAdder`等原子类型,以及`ForkJoinPool`和`Parallel Streams`的引入,提高了多线程环境下的性能。 **9. Nashorn ...

    Java_1.8中文API.rar

    10. **新数据类型**:为了节省内存,Java 8引入了新的原始数据类型,如`java.util.LongAdder`和`java.util.DoubleAdder`,它们在多线程环境下提供高效累加操作。 Java API文档是学习和开发Java应用的必备工具,通过...

    jdk-8u291-macosx-x64.dmg.zip

    8. **新的数值类型**:如`LongAdder`和`DoubleAdder`,提供了线程安全的计数,提高了性能。 **macOS上的Java安装与配置** 在macOS上安装JDK 1.8通常涉及以下步骤: 1. 解压缩下载的"jdk-8u291-macosx-x64.dmg...

    中文版jdk1.8的API.rar

    在这个“中文版jdk1.8的API.rar”压缩包中,包含的是JDK 1.8的API文档的中文翻译版,对于中文使用者来说,这是一份非常宝贵的资源,能帮助开发者更好地理解和使用Java 1.8的各类库和接口。 API(Application ...

Global site tag (gtag.js) - Google Analytics