AtomicInteger,一个提供原子操作的Integer的类。在Java语言中,++i和i++操作并不是线程安全的,在使用的时候,不可避免的会用到synchronized关键字。而AtomicInteger则通过一种线程安全的加减操作接口。
来看AtomicInteger提供的接口。
//获取当前的值
public final int get()
//取当前的值,并设置新的值
public final int getAndSet(int newValue)
//获取当前的值,并自增
public final int getAndIncrement()
//获取当前的值,并自减
public final int getAndDecrement()
//获取当前的值,并加上预期的值
public final int getAndAdd(int delta)
... ...
我们在上一节提到的CAS主要是这两个方法
public final boolean compareAndSet(int expect, int update) {
return unsafe.compareAndSwapInt(this, valueOffset, expect, update);
}
public final boolean weakCompareAndSet(int expect, int update) {
return unsafe.compareAndSwapInt(this, valueOffset, expect, update);
}
这两个方法是名称不同,但是做的事是一样的,可能在后续的java版本里面会显示出区别来。
详细查看会发现,这两个接口都是调用一个unsafe的类来操作,这个是通过JNI实现的本地方法,细节就不考虑了。
下面是一个对比测试,我们写一个synchronized的方法和一个AtomicInteger的方法来进行测试,直观的感受下性能上的差异
- package zl.study.concurrency;
- import java.util.concurrent.atomic.AtomicInteger;
- public class AtomicIntegerCompareTest {
- private int value;
-
- public AtomicIntegerCompareTest(int value){
- this.value = value;
- }
-
- public synchronized int increase(){
- return value++;
- }
-
- public static void main(String args[]){
- long start = System.currentTimeMillis();
-
- AtomicIntegerCompareTest test = new AtomicIntegerCompareTest(0);
- for( int i=0;i< 1000000;i++){
- test.increase();
- }
- long end = System.currentTimeMillis();
- System.out.println("time elapse:"+(end -start));
-
- long start1 = System.currentTimeMillis();
-
- AtomicInteger atomic = new AtomicInteger(0);
-
- for( int i=0;i< 1000000;i++){
- atomic.incrementAndGet();
- }
- long end1 = System.currentTimeMillis();
- System.out.println("time elapse:"+(end1 -start1) );
-
-
- }
- }
结果
time elapse:31
time elapse:16
由此不难看出,通过JNI本地的CAS性能远超synchronized关键字
分享到:
相关推荐
在多线程编程中,线程对共享变量的访问不是直接与主存交互,而是通过各自的工作内存(高速缓存)进行。JMM规定了工作内存和主存之间的交互规则,从而保证了线程间能够正确地读取和更新共享变量的值。 总而言之,...
### Java多线程编程知识点详解 #### 一、线程基础概述 - **定义与特点:** - **线程**是一种比进程更细粒度的执行单元,它允许在一个进程中并发执行多个任务。 - **轻量级进程**:线程有时被称为轻量级进程,...
线程安全是多线程编程中的一个重要概念,指的是在多线程环境下,一个类或者对象的行为不会因为线程的并发访问而导致不正确的结果。在Java中,我们通常通过以下几种方式来保证线程安全: 1. **同步机制**:包括`...
### Java多线程编程教程知识点概述 #### 一、操作系统中的线程与进程概念 - **进程**: 进程是操作系统进行资源分配和调度的基本单位,每个进程在内存中都有独立的一块空间。例如,在Windows系统中,一个运行的`....
《Java-jdk10-最新最全多线程编程实战指南-核心篇》是一本深入探讨Java多线程编程的专著,针对Java 10版本进行了全面的更新和优化。这本书聚焦于Java多线程的核心概念和技术,旨在帮助开发者理解和掌握如何在并发...
Java并发编程是Java开发中的重要领域,涉及到多线程、并发控制、同步机制等多个知识点。以下是对Java并发知识体系的详细解析。 首先,我们要理解并发的理论基础。并发是为了提高系统资源利用率和处理能力,让多个...
Java多线程编程是一个深奥且复杂的话题,它涉及到内存模型、线程调度、同步机制等多个层面的知识。Java通过提供丰富的API和并发工具库,使得开发者能够有效地利用多线程技术来构建高效的并发应用程序。对于Java...
- Java多线程编程涉及多个方面的知识和技术,从基本的线程创建到高级的同步机制,都是开发高效、可靠的多线程应用程序所必需的。 - 正确理解和使用这些技术对于提高程序性能、避免死锁等问题至关重要。
Java多线程编程是Java平台的核心特性之一,它允许程序同时执行多个独立的代码段,提高了CPU资源的利用率。在Java中,线程可以被理解为程序中的执行流,它们在一个进程中并发运行,共享进程的资源,如内存空间。本文...
Java多线程编程技术是Java开发中的重要组成部分,它允许程序同时执行多个任务,从而提高系统资源利用率和程序性能。本书籍旨在深入探讨Java多线程的开发与编程技术,适合那些已经具备一定多线程基础知识的开发者...
本教程将深入探讨如何利用Java进行多线程编程,并结合Http协议实现断点续传功能,这在大文件传输场景中尤为实用。 一、Java多线程 1. 线程的创建:Java提供了多种方式创建线程,包括继承Thread类、实现Runnable...
Java多线程编程是提升程序性能和响应性的关键技术。理解多线程的概念,掌握线程的创建、同步、通信、死锁避免等核心知识点,以及合理使用线程池,对于编写高效、稳定的并发程序至关重要。通过实践,开发者可以更好地...
Java多线程编程是Java开发中的重要组成部分,尤其对于大型应用程序和并发性能要求较高的系统而言。虽然Java在多线程方面可能不如C++灵活,但Java提供了强大的平台无关性和自动内存管理,使得开发者可以专注于并发...
《Java多线程编程核心技术》是一本由资深Java专家倾力打造的专业著作,结合了作者10年的实战经验,深入浅出地解析了Java多线程编程的核心概念和技术。本书以丰富的案例为引导,旨在帮助读者全面理解和掌握Java平台上...
Java多线程设计模式是Java开发中的重要领域,它涉及到并发编程、系统性能优化以及程序的稳定性。在Java中,多线程允许程序同时执行多个任务,极大地提升了程序的执行效率。本资源提供了详细的Java多线程设计模式的...
│ 高并发编程第一阶段26讲、多线程下的生产者消费者模型,以及详细介绍notifyAll方法.mp4 │ 高并发编程第一阶段27讲、wait和sleep的本质区别是什么,深入分析(面试常见问题).mp4 │ 高并发编程第一阶段28讲、...
### 深入浅出Java多线程.pdf #### 知识点概览 本PDF文档涉及了Java多线程的全面介绍,分为基础篇、原理篇和JDK工具篇三个部分,旨在帮助读者深入了解Java多线程的概念、原理及实践应用。 #### 基础篇 **1. 进程...
根据给定文件的信息,我们...通过以上知识点的学习,开发者可以深入理解Java多线程编程的核心概念和技术细节,为实际开发工作打下坚实的基础。同时,掌握这些高级并发技术对于构建高性能、高可靠性的应用系统至关重要。