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();
}
}
}
}
这是卖票的经典案例,在这做个记录。