51Testing软件测试论坛

 找回密码
 (注-册)加入51Testing

QQ登录

只需一步,快速开始

微信登录,快人一步

手机号码,快捷登录

查看: 1317|回复: 4
打印 上一主题 下一主题

Synchronized加锁后为什么还会出现意想不到的的情况?

[复制链接]
  • TA的每日心情
    无聊
    4 天前
  • 签到天数: 530 天

    连续签到: 2 天

    [LV.9]测试副司令

    跳转到指定楼层
    1#
    发表于 2022-1-25 10:41:07 | 只看该作者 回帖奖励 |倒序浏览 |阅读模式
    1测试积点
    问题遇到的现象和发生背景

    最近刚开始学java的Synchronized关键字,了解到互斥锁,测试了一下,但是结果却跟学到的不一样,我模拟的是卖票的情况,退出条件为卖完即退出,大多数情况下都能正常,但是多测几次发现会出现超卖的情况,谁能帮忙解答一下吗?

    1. package concurrent;
    2. public class SellTicketTest {
    3.     public static void main(String[] args) {
    4.         SellTicket sellTicket = new SellTicket();
    5.         Thread thread = new Thread(sellTicket);
    6.         Thread thread1 = new Thread(sellTicket);
    7.         Thread thread2 = new Thread(sellTicket);
    8.         Thread thread3 = new Thread(sellTicket);
    9.         thread3.start();
    10.         thread.start();
    11.         thread1.start();
    12.         thread2.start();
    13.     }
    14. }
    15. class SellTicket implements Runnable{
    16.     private int ticketNum=100;
    17.     private boolean loop=true;
    18.     public synchronized void sell(){//加锁的位置
    19.             System.out.println(Thread.currentThread().getName() + "窗口卖出一张票" + "还剩下" + (--ticketNum) + "张票");
    20.             if(ticketNum<=0){//退出的条件
    21.                 System.out.println("售票结束");
    22.                 loop=false;
    23.         }
    24.     }
    25.     @Override
    26.     public void run() {
    27.         while (loop){
    28.             sell();
    29.            }
    30.     }
    31. }
    复制代码

    运行结果及报错内容

    1. Thread-2窗口卖出一张票还剩下1张票
    2. Thread-2窗口卖出一张票还剩下0张票
    3. 售票结束
    4. Thread-1窗口卖出一张票还剩下-1张票
    5. 售票结束
    6. Thread-0窗口卖出一张票还剩下-2张票
    7. 售票结束
    8. Thread-3窗口卖出一张票还剩下-3张票
    9. 售票结束
    复制代码
    我的解答思路和尝试过的方法

    本以为是加锁的位置不对,或者是创建了不同的对象,但是检查后发现并没有创建多个对象

    我想要达到的结果

    有哪位能指点迷津吗?感谢感谢


    分享到:  QQ好友和群QQ好友和群 QQ空间QQ空间 腾讯微博腾讯微博 腾讯朋友腾讯朋友
    收藏收藏
    回复

    使用道具 举报

  • TA的每日心情
    奋斗
    4 小时前
  • 签到天数: 669 天

    连续签到: 1 天

    [LV.9]测试副司令

    2#
    发表于 2022-1-26 09:22:13 | 只看该作者
    回复

    使用道具 举报

  • TA的每日心情
    奋斗
    3 小时前
  • 签到天数: 1522 天

    连续签到: 1 天

    [LV.Master]测试大本营

    3#
    发表于 2022-1-26 10:24:47 | 只看该作者
    看数量的判断是最后还是一开始
    回复

    使用道具 举报

  • TA的每日心情
    奋斗
    2024-10-22 14:23
  • 签到天数: 1007 天

    连续签到: 1 天

    [LV.10]测试总司令

    4#
    发表于 2022-1-26 15:19:53 | 只看该作者
    回复

    使用道具 举报

  • TA的每日心情
    奋斗
    6 小时前
  • 签到天数: 2819 天

    连续签到: 1 天

    [LV.Master]测试大本营

    5#
    发表于 2022-1-26 17:21:04 | 只看该作者
    一样,你要看加锁以后的状态变化
    回复

    使用道具 举报

    本版积分规则

    关闭

    站长推荐上一条 /1 下一条

    小黑屋|手机版|Archiver|51Testing软件测试网 ( 沪ICP备05003035号 关于我们

    GMT+8, 2024-11-25 13:27 , Processed in 0.062208 second(s), 22 queries .

    Powered by Discuz! X3.2

    © 2001-2024 Comsenz Inc.

    快速回复 返回顶部 返回列表