JUC并发编程

wait/sleep区别

来自不同的类

wait->object

sleep->Thread

 

wait会释放锁

sleep会抱着锁睡觉

Synchronized和Lock区别

JUC并发编程

 

 

.notifyAll();通知其他线程
.wait();等待 (会释放锁)


(if改为while防止虚假唤醒)
package lock;

import java.util.concurrent.locks.Lock;

public class demo1 {
public static void main(String[] args) {
Data data=new Data();
new Thread(()->{
for (int i = 0; i <10; i++) {
try {
data.increment();
} catch (InterruptedException e) {
e.printStackTrace();
}
}
},"A").start();
new Thread(()->{
for (int i = 0; i <10; i++) {
try {
data.Decrement();
} catch (InterruptedException e) {
e.printStackTrace();
}
}
},"B").start();
new Thread(()->{
for (int i = 0; i <10 ; i++) {
try {
data.increment();
} catch (InterruptedException e) {
e.printStackTrace();
}
}
},"C").start();
new Thread(()->{
for (int i = 0; i <10 ; i++) {
try {
data.Decrement();
} catch (InterruptedException e) {
e.printStackTrace();
}
}
},"D").start();

}
}
class Data{
private int number=0;
public synchronized void increment() throws InterruptedException {
if (number!=0){//0
this.wait();//等待
}
number++;//加1
System.out.println(Thread.currentThread().getName()+"->"+number);//获取当前线程的名字跟数量
this.notifyAll();//通知其他线程加一完毕

}
public synchronized void Decrement() throws InterruptedException {
if (number==0){
this.wait();//等待
}
number--;//减一
System.out.println(Thread.currentThread().getName()+"->"+number);//获取当前线程的名字跟数量
this.notifyAll();//通知其他线程减一完毕

}
}

拿两个加法线程A、B来说,比如A先执行,执行时调用了wait方法,那它会等待,此时会释放锁,那么线程B获得锁并且也会执行wait方法,两个加线程一起等待被唤醒。
此时减线程中的某一个线程执行完毕并且唤醒了这俩加线程,那么这俩加线程不会一起执行,其中A获取了锁并且加1,执行完毕之后B再执行。如果是if的话,那么A修改完num后,
B不会再去判断num的值,直接会给num+1。如果是while的话,A执行完之后,B还会去判断num的值,因此就不会执行。

 JUC并发编程

 

上一篇:Linux下使用FreeBSD的ee


下一篇:字符串和内存函数小记