java多线程卖票直接先看个例子: public class SelTicketsMainTest { public static void main(String[] args) { SaleTickets1 saleTickets = new SaleTickets1(); for(int t=1;t=3;t++) { new Thread(saleTickets).start(); } }} class SaleTic
java多线程卖票直接先看个例子:
public class SelTicketsMainTest { public static void main(String[] args) { SaleTickets1 saleTickets = new SaleTickets1(); for(int t=1;t<=3;t++) { new Thread(saleTickets).start(); } } } class SaleTickets1 implements Runnable{ private int ticketCount = 10;// 总的票数,这个是共享资源,多个线程都会访问 public void run() { while (true)// 循环是指线程不停的去卖票 { synchronized (this)// 当操作的是共享数据时, // 用同步代码块进行包围起来,执行里面的代码需要mutex的锁,但是mutex只有一个锁。这样在执行时,只能有一个线程执行同步代码块里面的内容 { if(ticketCount>0) { ticketCount--; System.out.println(Thread.currentThread().getName() + "正在卖票,还剩" + ticketCount + "张票"); } } /** * 在同步代码块里面睡觉,和不睡效果是一样 的,作用只是自已不执行,也不让线程执行。sleep不释放锁,抱着锁睡觉。其他线程拿不到锁,也不能执行同步代码。wait()可以释放锁 * 所以把睡觉放到同步代码块的外面,这样卖完一张票就睡一会,让其他线程再卖,这样所有的线程都可以卖票 */ try { Thread.sleep(100); } catch (InterruptedException e) { e.printStackTrace(); } } } }
这是卖票的经典案例,在这做个记录。
以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持自由互联。