2 u010442664 u010442664 于 2014.02.11 01:29 提问

请问为什么第二段代码无法正确运行?

package threadlearning;

public class BankThread {

public static void main(String[] args) {
    // TODO Auto-generated method stub
    ChuHu ch1=new ChuHu();
    ChuHu ch2=new ChuHu();
    Thread t1=new Thread(ch1,"aaa");
    Thread t2=new Thread(ch2,"kkk");
    t1.start();
    t2.start();

}

}

class Bank {
static int jinKu = 0;
}

class ChuHu implements Runnable {
public void run() {
synchronized (new Object()) {
for (int i = 1; i <= 3; i++) {
System.out.println(Thread.currentThread().getName() + "第" + i

                    + "次存入100元后金库里总额为:" + (Bank.jinKu+=100));
        }
    }
}

}
运行结果为:
aaa第1次存入100元后金库里总额为:100
kkk第1次存入100元后金库里总额为:200
aaa第2次存入100元后金库里总额为:300
kkk第2次存入100元后金库里总额为:400
aaa第3次存入100元后金库里总额为:500

而使用第二段代码就无法正确运行,这是为什么???
package threadlearning;

public class BankThread {

public static void main(String[] args) {
    // TODO Auto-generated method stub
    ChuHu ch1=new ChuHu();
    ChuHu ch2=new ChuHu();
    Thread t1=new Thread(ch1,"aaa");
    Thread t2=new Thread(ch2,"kkk");
    t1.start();
    t2.start();

}

}

class Bank {
static int jinKu = 0;
}

class ChuHu implements Runnable {
public void run() {
synchronized (new Object()) {
for (int i = 1; i <= 3; i++) {
Bank.jinKu += 100;
System.out.println(Thread.currentThread().getName() + "第" + i
+ "次存入100元后金库里总额为:" + Bank.jinKu);
}
}
}
}
运行结果为:-----
kkk第1次存入100元后金库里总额为:200
kkk第2次存入100元后金库里总额为:300
aaa第1次存入100元后金库里总额为:200
kkk第3次存入100元后金库里总额为:400
aaa第2次存入100元后金库里总额为:500
aaa第3次存入100元后金库里总额为:600

2个回答

p451933505
p451933505   2014.02.11 15:22

感觉线性同步错乱了 我帮补了你 debug了下 每次debug运行没问题

tianyufeixiang9
tianyufeixiang9   2014.02.12 14:21

你的线程同步有问题,第一、你加的锁在for循环外边,第二、我觉得你加锁是 new Object(),给你一新创建的对象加锁?第三、个人感觉虽然第一个结果貌似对了,我觉得逻辑还是不对
建议ChuHu 改成
class ChuHu implements Runnable {
static Object o = new Object();
public void run() {
for (int i = 1; i <= 3; i++) {
synchronized (o) {
Bank.jinKu += 100;
System.out.println(Thread.currentThread().getName() + "第" + i
+ "次存入100元后金库里总额为:" + Bank.jinKu);
}
}
}
}

u010442664
u010442664 谢谢。了解了。
3 年多之前 回复
Csdn user default icon
上传中...
上传图片
插入图片