ala808yi 2015-07-15 09:41 采纳率: 100%
浏览 1632
已采纳

java Thread线程tickets问题

刚学thread,怎么控制台输出会有重复的数目,求大神解答

public class Ticket implements Runnable{
public static int count = 5;
private String name;
public void run(){
for(int i=0;i<=4;i++){
try{
Thread.sleep(1000);
}catch(Exception e){
e.printStackTrace();
}
if(count >0 ){
System.out.println(Thread.currentThread().getName()+",count= " + this.count--);
}
}
}
public Ticket(){

}
public Ticket(String name){
    this.name = name;
}
public static void main(String[] args){
    Ticket ticket = new Ticket();
    new Thread(ticket,"A").start();
    new Thread(ticket,"B").start();
    new Thread(ticket,"C").start();

}

}

consoles:
B,count= 5
A,count= 5
C,count= 4
B,count= 3
A,count= 2
C,count= 1

  • 写回答

3条回答

  • danielinbiti 2015-07-15 10:01
    关注
    public static int count = 5;
    改成
    public static Integer count = 5;
    
    if(count >0 ){
    System.out.println(Thread.currentThread().getName()+",count= " + this.count--);
    }
    改成
    synchronized(count){//增加同步锁,当一个线程访问count时,其他不能访问
        if(count >0 ){
          System.out.println(Thread.currentThread().getName()+",count= " + this.count--);
        }
    }
    
    本回答被题主选为最佳回答 , 对您是否有帮助呢?
    评论
查看更多回答(2条)

报告相同问题?

悬赏问题

  • ¥15 乘性高斯噪声在深度学习网络中的应用
  • ¥15 运筹学排序问题中的在线排序
  • ¥15 关于docker部署flink集成hadoop的yarn,请教个问题 flink启动yarn-session.sh连不上hadoop,这个整了好几天一直不行,求帮忙看一下怎么解决
  • ¥30 求一段fortran代码用IVF编译运行的结果
  • ¥15 深度学习根据CNN网络模型,搭建BP模型并训练MNIST数据集
  • ¥15 C++ 头文件/宏冲突问题解决
  • ¥15 用comsol模拟大气湍流通过底部加热(温度不同)的腔体
  • ¥50 安卓adb backup备份子用户应用数据失败
  • ¥20 有人能用聚类分析帮我分析一下文本内容嘛
  • ¥30 python代码,帮调试,帮帮忙吧