java线程间隔启动_java两个线程间隔递增打印数字 (synchronized wait notify的使用)...

本文通过一个Java多线程示例,展示了在使用`synchronized`关键字时可能出现的问题——在一个线程中修改了锁定对象的值,导致其他线程在持有不同值的监视器上调用`notify()`方法而抛出错误。文章讨论了线程同步的重要性以及如何避免此类错误,包括正确使用`wait()`和`notify()`方法,以及确保在同步块中保持一致的数据状态。
摘要由CSDN通过智能技术生成

public class ThreadTest {

public static int counter = 0;

public static Integer lock = 0;;

public static void main(String ... arg){

Thread t1 = new Thread(){

public void run(){

for(int i=0;i<10;i++){

synchronized (lock) {

lock.notify();

try {

System.out.println("thread" + Thread.currentThread().getId() + " print " + i);

lock.wait();

} catch (InterruptedException e) {

e.printStackTrace();

}

}

}

}

};

Thread t2 = new Thread(){

public void run(){

for(int i=0;i<10;i++){

synchronized (lock) {

lock.notify();

try {

System.out.println("thread" + Thread.currentThread().getId() + " print " + i);

lock.wait();

} catch (InterruptedException e) {

e.printStackTrace();

}

}

}

}

};

t1.start();

t2.start();

}

}

你在lock对象上面上锁,但是你居然修改lock的值。

你的代码为报错原因是:

This method(notify/wait) should only be called by a thread that is the owner of this object's monitor.

hread t1 = new Thread(){

public void run(){

for(int i=0;i<10;i++){

synchronized (lock) {//获取lock=0的对象的监视器

try {

while(lock%2==0){

lock.wait();

}

System.out.println("1 "+lock);

lock+=1;//你居然修改了这个对象

} catch (InterruptedException e) {

e.printStackTrace();

}

lock.notify();//此时lock的值不为0了,但是该线程拥有的是lock=0的对象监视器,这个时候调用notify方法就报错了,因为notify必须使用线程拥有的监视器对应对象调用。

}

}

}

};

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值