需求:
某电影院目前正在上映国产大片,共有100张票,而它有3个窗口卖票,请设计一一个程序模拟该电影院卖票
思路:
①定义一个类SellTicket实现Runnable接口, 里面定义一个成员变量: private int tickets= 100;
②在SellTicket类中重写run0方法实现卖票,代码步骤如下
A:判断票数大于0,就卖票,并告知是哪个窗口卖的
B:卖了票之后,总票数要减1
C:票没有了,也可能有人来问,所以这里用死循环让卖票的动作- -直执行
③义一个测试类SellTicketDemo,里面有main方法,代码步骤如下
A:创建SellTicket类的对象
B:创建三个Thread类的对象,把SellTicket对象作为构造方法的参数,并给出对应的窗口名称
C:启动线程
1.创建一个Runnable的实现类SellTicket
public class SellTicket implements Runnable { private int tickets = 100; // private Object obj = new Object(); private Lock lock = new ReentrantLock(); @Override public void run() { while (true) { // synchronized (obj) { try { lock.lock(); if (tickets > 0) { try { Thread.sleep(100); } catch (InterruptedException e) { e.printStackTrace(); } System.out.println(Thread.currentThread().getName() + "正在出售:" + tickets + "张票"); tickets--; // } } }finally { lock.unlock(); } } } }
2.创建一个SellTicket类的测试类SellTicketDemo
public class SellTicketDemo { public static void main(String[] args) { SellTicket st = new SellTicket(); Thread t1 = new Thread(st,"窗口一"); Thread t2 = new Thread(st,"窗口二"); Thread t3 = new Thread(st,"窗口三"); t1.start(); t2.start(); t3.start(); } }
关于同步:
如果不加synchronized()的话,就会出现三个进程抢CPU,而在这个例子中三个进程分别sleep100毫秒之后就又开始抢占CPU了,线程就是不安全的,得同步一下。
另一种方法就是Lock接口,JDK5后出现了一个Lock接口,创建一个Lock的实现类Reentrantlock对象,通过调用该对象的lock方法和unlock方法(Lock接口中的方法)对要执行运行代码语句加锁实现线程安全达到同步。
欢迎分享,转载请注明来源:内存溢出
评论列表(0条)