模拟商品销售功能
package com.xgx.demo2;
public class Example11_4 implements Runnable{
private int goodsCount = 5;
public void sellGoods(){
if(goodsCount>0){
System.out.println(Thread.currentThread().getName()+"正在出售第"+(5-goodsCount+1)+"件库存商品,"+"还剩"+(--goodsCount)+"库存");
}else{
System.out.println("该商品已经售完!");
}
}
public void run(){
while (goodsCount>0){
sellGoods();
try{
Thread.sleep(100);
}catch (InterruptedException e){
e.printStackTrace();
}
}
}
}
窗口2正在出售第1件库存商品,还剩4库存
窗口1正在出售第1件库存商品,还剩2库存
窗口3正在出售第1件库存商品,还剩3库存
窗口4正在出售第4件库存商品,还剩1库存
窗口3正在出售第5件库存商品,还剩0库存
窗口1正在出售第5件库存商品,还剩-2库存
窗口2正在出售第5件库存商品,还剩-1库存
窗口4正在出售第5件库存商品,还剩-1库存
//结果所示,但结果有问题,还需改进
如果改成goodsCount--
窗口3正在出售第1件库存商品,还剩5库存
窗口1正在出售第4件库存商品,还剩2库存
窗口4正在出售第3件库存商品,还剩3库存
窗口2正在出售第2件库存商品,还剩4库存
窗口4正在出售第5件库存商品,还剩1库存
窗口2正在出售第5件库存商品,还剩1库存
窗口3正在出售第5件库存商品,还剩0库存
窗口1正在出售第5件库存商品,还剩1库存//结果所示,符合逻辑,但仍需要改进
package com.xgx.demo2;
public class Example11_4 implements Runnable{
private int goodsCount = 5;
public synchronized void sellGoods(){
if(goodsCount>0){
System.out.println(Thread.currentThread().getName()+"正在出售第"+(5-goodsCount+1)+"件库存商品,"+"还剩"+(goodsCount--)+"库存");
}else{
System.out.println("该商品已经售完!");
}
}
public void run(){
while (goodsCount>0){
sellGoods();
try{
Thread.sleep(100);
}catch (InterruptedException e){
e.printStackTrace();
}
}
}
}
//如果加上synchyronized关键字,结果如下
窗口1正在出售第1件库存商品,还剩5库存
窗口4正在出售第2件库存商品,还剩4库存
窗口3正在出售第3件库存商品,还剩3库存
窗口2正在出售第4件库存商品,还剩2库存
窗口3正在出售第5件库存商品,还剩1库存
该商品已经售完!
//非常好!