AtomicInteger使用非阻塞算法,实现并发控制多线程实现售票

简介: AtomicInteger使用非阻塞算法,实现并发控制多线程实现售票
代码如下:
public class TicketDemo implements Runnable {
    private static volatile AtomicInteger ticketSum = new AtomicInteger(20);
    private static int finalTotal = 0;
 
    @Override
    public void run() {
        int count;
        while ((count = ticketSum.decrementAndGet()) >= 0) {
            System.out.println(Thread.currentThread().getName() + "卖出了第" + ++count + "张票");
            finalTotal++;
        }
    }
 
    public static void main(String[] args) {
        Thread t1 = new Thread(new TicketDemo(), "t1");
        Thread t2 = new Thread(new TicketDemo(), "t2");
        Thread t3 = new Thread(new TicketDemo(), "t3");
        long startTime = System.currentTimeMillis();
        t1.start();
        t2.start();
        t3.start();
        while (true) {
            if (!t1.isAlive() && !t2.isAlive() && !t3.isAlive()) {
                long endTime = System.currentTimeMillis();
                System.out.println("最终售出:" + finalTotal);
                System.out.println("最终耗时:" + (endTime - startTime) + "毫秒.");
                break;
            }
        }
    }
}

总结:


多线程必须加上synchronized,保证不会出现并发线程同时访问的情况,而在AtomicInteger中却不用加上synchronized,AtomicInteger是一个提供原子操作的Integer类,通过线程安全的方式操作加减,AtomicInteger是在使用非阻塞算法实现并发控制,在一些高并发程序中非常适合,但并不能每一种场景都适合,不同场景要使用使用不同的数值类。

以上为AtomicInteger中的部分源码,在这里说下其中的value,这里value使用了volatile关键字,volatile在这里可以做到的作用是使得多个线程可以共享变量,但是问题在于使用volatile将使得VM优化失去作用,导致效率较低,所以要在必要的时候使用,因此AtomicInteger类不要随意使用,要在使用场景下使用。

————————————————


                           版权声明:本文为博主原创文章,遵循 CC 4.0 BY-SA 版权协议,转载请附上原文出处链接和本声明。

                     

原文链接:https://blog.csdn.net/W_317/article/details/106136028

相关文章
|
2天前
|
数据采集 存储 Java
高德地图爬虫实践:Java多线程并发处理策略
高德地图爬虫实践:Java多线程并发处理策略
|
2天前
|
安全 C++
C++多线程编程:并发与同步
C++多线程编程:并发与同步
10 0
|
2天前
|
安全 Java
Java中的并发编程:理解并发性与线程安全
Java作为一种广泛应用的编程语言,在并发编程方面具有显著的优势和特点。本文将探讨Java中的并发编程概念,重点关注并发性与线程安全,并提供一些实用的技巧和建议,帮助开发人员更好地理解和应用Java中的并发机制。
|
2天前
多线程售票demo,用ReentrantLock实现
多线程售票demo,用ReentrantLock实现
|
2天前
|
Java
java多线程售票例子
java多线程售票例子
|
2天前
|
存储 安全 Java
【亮剑】`ConcurrentHashMap`是Java中线程安全的哈希表,采用锁定分离技术提高并发性能
【4月更文挑战第30天】`ConcurrentHashMap`是Java中线程安全的哈希表,采用锁定分离技术提高并发性能。数据被分割成多个Segment,每个拥有独立锁,允许多线程并发访问不同Segment。当写操作发生时,计算键的哈希值定位Segment并获取其锁;读操作通常无需锁定。内部会根据负载动态调整Segment,减少锁竞争。虽然使用不公平锁,但Java 8及以上版本提供了公平锁选项。理解其工作原理对开发高性能并发应用至关重要。
|
2天前
|
设计模式 Java 编译器
深入理解Java中的多线程并发控制
Java作为一种流行的编程语言,其多线程并发控制机制一直是开发者关注的焦点。本文旨在通过探讨Java中的多线程并发控制原理、常用同步工具及设计模式,帮助读者深入理解并有效应用多线程并发控制技术,以提高程序性能和稳定性。
|
2天前
|
监控 安全 Java
一文讲明白Java中线程与进程、并发与并行、同步与异步
一文讲明白Java中线程与进程、并发与并行、同步与异步
8 1
|
2天前
|
安全 Java
深入理解 Java 多线程和并发工具类
【4月更文挑战第19天】本文探讨了Java多线程和并发工具类在实现高性能应用程序中的关键作用。通过继承`Thread`或实现`Runnable`创建线程,利用`Executors`管理线程池,以及使用`Semaphore`、`CountDownLatch`和`CyclicBarrier`进行线程同步。保证线程安全、实现线程协作和性能调优(如设置线程池大小、避免不必要同步)是重要环节。理解并恰当运用这些工具能提升程序效率和可靠性。
|
2天前
|
安全 Java
java多线程(一)(火车售票)
java多线程(一)(火车售票)