java多线程-Atomic

来源:互联网 发布:fastcopy 网络拷贝 编辑:程序博客网 时间:2024/06/05 18:32

Atomic原子包简单使用,此处用AtomicInteger来进行计数(其他的都差不多)

import java.util.concurrent.atomic.AtomicInteger;public class Ticket {    public final  AtomicInteger x = new AtomicInteger(1000000);}

以买票为例,此处为票的数量,一个简单的类,接着调用线程来去买票。

class BuyTicket implements Runnable {    private Ticket ticket;    public BuyTicket(Ticket ticket) {        this.ticket = ticket;    }    @Override    public void run() {           ticket.x.getAndAdd(-1);    }}

调用10000个线程去买票

public class BuyTicketThreadDemo {    public static void main(String args[]) throws InterruptedException {        Ticket ticket = new Ticket();        System.out.printf("\n票的余数 = %d\n", ticket.x.get());        Runnable r1 = new BuyTicket(ticket);        Thread []thread = new Thread[10000];        for (int i = 0; i < 10000; i++) {            thread[i] = new Thread(r1);        }        for (int i = 0; i < 10000; i++) {            thread[i].start();         }        Thread.sleep(500);        System.out.println("\b\nThe remainder of the ticket is " + ticket.x.get());    }}

结果为990000,这是正确的。
具体的可以从这里看,写的很好,我就不重复说了java-多线程深入(五)Atomic
Java的Actomic类分析


现在考虑一种情况,如果我想买票之前判断票是否有剩余怎么办

class BuyTicket implements Runnable {    private Ticket ticket;    public BuyTicket(Ticket ticket) {        this.ticket = ticket;    }    @Override    public void run() {   //同步             if (ticket.x.addAndGet(-1) < 0) {            System.out.println("购买失败!");            ticket.x.getAndIncrement();        } else {            System.out.println("购买成功!");        }    }}

就相当于买的时候,先虚晃一下,看看买完是不是符合条件,如果不符合,就还回去。

原创粉丝点击