学习过程观看视频:[狂神说Java]
https://www.bilibili.com/video/BV1B7411L7tE?p=2
欢迎大家支持噢,很良心的老师了!
线程通信案例:
package com.zjl;
/**
* Created by zjl
* 2020/11/20
**/
/*
* 1、线程之间的通信问题:生产者和消费者问题!
* 2、线程交替执行,A B 操作同一个变量 num = 0
* 3、A num+1
* 4、B num-1
* */
public class Test {
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();
}
}
}).start();
new Thread(()->{
for (int i = 0; i < 10; i++) {
try {
data.decrement();
} catch (InterruptedException e) {
e.printStackTrace();
}
}
}).start();
}
}
//等待-----》业务-----》通知
class Data{ //数字,资源类
private int number = 0;
//+1
public synchronized void increment() throws InterruptedException {
if(number!=0){
//等待
this.wait();
}
number++;
System.out.println("我加一完毕了+++++++++++++++++++++++++唤醒其他线程减一" + number);
this.notifyAll();
}
//-1
public synchronized void decrement() throws InterruptedException {
if(number == 0){
//等待
this.wait();
}
number--;
System.out.println("我减一完毕了--------------------------唤醒其他线程加一" + number);
this.notifyAll();
}
}
执行结果:
/Library/Java/JavaVirtualMachines/jdk1.8.0_231.jdk/Contents/Home/bin/java "-javaagent:/Users/zhangjianlong/Library/Application Support/JetBrains/Toolbox/apps/IDEA-U/ch-0/193.5662.53/IntelliJ IDEA.app/Contents/lib/idea_rt.jar=59773:/Users/zhangjianlong/Library/Application Support/JetBrains/Toolbox/apps/IDEA-U/ch-0/193.5662.53/IntelliJ IDEA.app/Contents/bin" -Dfile.encoding=UTF-8 -classpath /Library/Java/JavaVirtualMachines/jdk1.8.0_231.jdk/Contents/Home/jre/lib/charsets.jar:/Library/Java/JavaVirtualMachines/jdk1.8.0_231.jdk/Contents/Home/jre/lib/deploy.jar:/Library/Java/JavaVirtualMachines/jdk1.8.0_231.jdk/Contents/Home/jre/lib/ext/cldrdata.jar:/Library/Java/JavaVirtualMachines/jdk1.8.0_231.jdk/Contents/Home/jre/lib/ext/dnsns.jar:/Library/Java/JavaVirtualMachines/jdk1.8.0_231.jdk/Contents/Home/jre/lib/ext/jaccess.jar:/Library/Java/JavaVirtualMachines/jdk1.8.0_231.jdk/Contents/Home/jre/lib/ext/jfxrt.jar:/Library/Java/JavaVirtualMachines/jdk1.8.0_231.jdk/Contents/Home/jre/lib/ext/localedata.jar:/Library/Java/JavaVirtualMachines/jdk1.8.0_231.jdk/Contents/Home/jre/lib/ext/nashorn.jar:/Library/Java/JavaVirtualMachines/jdk1.8.0_231.jdk/Contents/Home/jre/lib/ext/sunec.jar:/Library/Java/JavaVirtualMachines/jdk1.8.0_231.jdk/Contents/Home/jre/lib/ext/sunjce_provider.jar:/Library/Java/JavaVirtualMachines/jdk1.8.0_231.jdk/Contents/Home/jre/lib/ext/sunpkcs11.jar:/Library/Java/JavaVirtualMachines/jdk1.8.0_231.jdk/Contents/Home/jre/lib/ext/zipfs.jar:/Library/Java/JavaVirtualMachines/jdk1.8.0_231.jdk/Contents/Home/jre/lib/javaws.jar:/Library/Java/JavaVirtualMachines/jdk1.8.0_231.jdk/Contents/Home/jre/lib/jce.jar:/Library/Java/JavaVirtualMachines/jdk1.8.0_231.jdk/Contents/Home/jre/lib/jfr.jar:/Library/Java/JavaVirtualMachines/jdk1.8.0_231.jdk/Contents/Home/jre/lib/jfxswt.jar:/Library/Java/JavaVirtualMachines/jdk1.8.0_231.jdk/Contents/Home/jre/lib/jsse.jar:/Library/Java/JavaVirtualMachines/jdk1.8.0_231.jdk/Contents/Home/jre/lib/management-agent.jar:/Library/Java/JavaVirtualMachines/jdk1.8.0_231.jdk/Contents/Home/jre/lib/plugin.jar:/Library/Java/JavaVirtualMachines/jdk1.8.0_231.jdk/Contents/Home/jre/lib/resources.jar:/Library/Java/JavaVirtualMachines/jdk1.8.0_231.jdk/Contents/Home/jre/lib/rt.jar:/Library/Java/JavaVirtualMachines/jdk1.8.0_231.jdk/Contents/Home/lib/ant-javafx.jar:/Library/Java/JavaVirtualMachines/jdk1.8.0_231.jdk/Contents/Home/lib/dt.jar:/Library/Java/JavaVirtualMachines/jdk1.8.0_231.jdk/Contents/Home/lib/javafx-mx.jar:/Library/Java/JavaVirtualMachines/jdk1.8.0_231.jdk/Contents/Home/lib/jconsole.jar:/Library/Java/JavaVirtualMachines/jdk1.8.0_231.jdk/Contents/Home/lib/packager.jar:/Library/Java/JavaVirtualMachines/jdk1.8.0_231.jdk/Contents/Home/lib/sa-jdi.jar:/Library/Java/JavaVirtualMachines/jdk1.8.0_231.jdk/Contents/Home/lib/tools.jar:/Users/zhangjianlong/testCode/JUC-study/target/classes:/Users/zhangjianlong/apache-maven-3.6.3/repository/org/projectlombok/lombok/1.18.8/lombok-1.18.8.jar com.zjl.Test
我加一完毕了+++++++++++++++++++++++++唤醒其他线程减一1
我减一完毕了--------------------------唤醒其他线程加一0
我加一完毕了+++++++++++++++++++++++++唤醒其他线程减一1
我减一完毕了--------------------------唤醒其他线程加一0
我加一完毕了+++++++++++++++++++++++++唤醒其他线程减一1
我减一完毕了--------------------------唤醒其他线程加一0
我加一完毕了+++++++++++++++++++++++++唤醒其他线程减一1
我减一完毕了--------------------------唤醒其他线程加一0
我加一完毕了+++++++++++++++++++++++++唤醒其他线程减一1
我减一完毕了--------------------------唤醒其他线程加一0
我加一完毕了+++++++++++++++++++++++++唤醒其他线程减一1
我减一完毕了--------------------------唤醒其他线程加一0
我加一完毕了+++++++++++++++++++++++++唤醒其他线程减一1
我减一完毕了--------------------------唤醒其他线程加一0
我加一完毕了+++++++++++++++++++++++++唤醒其他线程减一1
我减一完毕了--------------------------唤醒其他线程加一0
我加一完毕了+++++++++++++++++++++++++唤醒其他线程减一1
我减一完毕了--------------------------唤醒其他线程加一0
我加一完毕了+++++++++++++++++++++++++唤醒其他线程减一1
我减一完毕了--------------------------唤醒其他线程加一0
Process finished with exit code 0
当我们把线程增加到4个的时候,会出现问题:
package com.zjl;
/**
* Created by zjl
* 2020/11/20
**/
/*
* 1、线程之间的通信问题:生产者和消费者问题!
* 2、线程交替执行,A B 操作同一个变量 num = 0
* 3、A num+1
* 4、B num-1
* */
public class Test {
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();
}
}
}).start();
new Thread(()->{
for (int i = 0; i < 10; i++) {
try {
data.decrement();
} catch (InterruptedException e) {
e.printStackTrace();
}
}
}).start();
new Thread(()->{
for (int i = 0; i < 10; i++) {
try {
data.increment();
} catch (InterruptedException e) {
e.printStackTrace();
}
}
}).start();
new Thread(()->{
for (int i = 0; i < 10; i++) {
try {
data.decrement();
} catch (InterruptedException e) {
e.printStackTrace();
}
}
}).start();
}
}
//等待-----》业务-----》通知
class Data{ //数字,资源类
private int number = 0;
//+1
public synchronized void increment() throws InterruptedException {
if(number!=0){
//等待
this.wait();
}
number++;
System.out.println("我加一完毕了+++++++++++++++++++++++++唤醒其他线程减一" + number);
this.notifyAll();
}
//-1
public synchronized void decrement() throws InterruptedException {
if(number == 0){
//等待
this.wait();
}
number--;
System.out.println("我减一完毕了--------------------------唤醒其他线程加一" + number);
this.notifyAll();
}
}
执行结果:
/Library/Java/JavaVirtualMachines/jdk1.8.0_231.jdk/Contents/Home/bin/java "-javaagent:/Users/zhangjianlong/Library/Application Support/JetBrains/Toolbox/apps/IDEA-U/ch-0/193.5662.53/IntelliJ IDEA.app/Contents/lib/idea_rt.jar=59846:/Users/zhangjianlong/Library/Application Support/JetBrains/Toolbox/apps/IDEA-U/ch-0/193.5662.53/IntelliJ IDEA.app/Contents/bin" -Dfile.encoding=UTF-8 -classpath /Library/Java/JavaVirtualMachines/jdk1.8.0_231.jdk/Contents/Home/jre/lib/charsets.jar:/Library/Java/JavaVirtualMachines/jdk1.8.0_231.jdk/Contents/Home/jre/lib/deploy.jar:/Library/Java/JavaVirtualMachines/jdk1.8.0_231.jdk/Contents/Home/jre/lib/ext/cldrdata.jar:/Library/Java/JavaVirtualMachines/jdk1.8.0_231.jdk/Contents/Home/jre/lib/ext/dnsns.jar:/Library/Java/JavaVirtualMachines/jdk1.8.0_231.jdk/Contents/Home/jre/lib/ext/jaccess.jar:/Library/Java/JavaVirtualMachines/jdk1.8.0_231.jdk/Contents/Home/jre/lib/ext/jfxrt.jar:/Library/Java/JavaVirtualMachines/jdk1.8.0_231.jdk/Contents/Home/jre/lib/ext/localedata.jar:/Library/Java/JavaVirtualMachines/jdk1.8.0_231.jdk/Contents/Home/jre/lib/ext/nashorn.jar:/Library/Java/JavaVirtualMachines/jdk1.8.0_231.jdk/Contents/Home/jre/lib/ext/sunec.jar:/Library/Java/JavaVirtualMachines/jdk1.8.0_231.jdk/Contents/Home/jre/lib/ext/sunjce_provider.jar:/Library/Java/JavaVirtualMachines/jdk1.8.0_231.jdk/Contents/Home/jre/lib/ext/sunpkcs11.jar:/Library/Java/JavaVirtualMachines/jdk1.8.0_231.jdk/Contents/Home/jre/lib/ext/zipfs.jar:/Library/Java/JavaVirtualMachines/jdk1.8.0_231.jdk/Contents/Home/jre/lib/javaws.jar:/Library/Java/JavaVirtualMachines/jdk1.8.0_231.jdk/Contents/Home/jre/lib/jce.jar:/Library/Java/JavaVirtualMachines/jdk1.8.0_231.jdk/Contents/Home/jre/lib/jfr.jar:/Library/Java/JavaVirtualMachines/jdk1.8.0_231.jdk/Contents/Home/jre/lib/jfxswt.jar:/Library/Java/JavaVirtualMachines/jdk1.8.0_231.jdk/Contents/Home/jre/lib/jsse.jar:/Library/Java/JavaVirtualMachines/jdk1.8.0_231.jdk/Contents/Home/jre/lib/management-agent.jar:/Library/Java/JavaVirtualMachines/jdk1.8.0_231.jdk/Contents/Home/jre/lib/plugin.jar:/Library/Java/JavaVirtualMachines/jdk1.8.0_231.jdk/Contents/Home/jre/lib/resources.jar:/Library/Java/JavaVirtualMachines/jdk1.8.0_231.jdk/Contents/Home/jre/lib/rt.jar:/Library/Java/JavaVirtualMachines/jdk1.8.0_231.jdk/Contents/Home/lib/ant-javafx.jar:/Library/Java/JavaVirtualMachines/jdk1.8.0_231.jdk/Contents/Home/lib/dt.jar:/Library/Java/JavaVirtualMachines/jdk1.8.0_231.jdk/Contents/Home/lib/javafx-mx.jar:/Library/Java/JavaVirtualMachines/jdk1.8.0_231.jdk/Contents/Home/lib/jconsole.jar:/Library/Java/JavaVirtualMachines/jdk1.8.0_231.jdk/Contents/Home/lib/packager.jar:/Library/Java/JavaVirtualMachines/jdk1.8.0_231.jdk/Contents/Home/lib/sa-jdi.jar:/Library/Java/JavaVirtualMachines/jdk1.8.0_231.jdk/Contents/Home/lib/tools.jar:/Users/zhangjianlong/testCode/JUC-study/target/classes:/Users/zhangjianlong/apache-maven-3.6.3/repository/org/projectlombok/lombok/1.18.8/lombok-1.18.8.jar com.zjl.Test
我加一完毕了+++++++++++++++++++++++++唤醒其他线程减一1
我减一完毕了--------------------------唤醒其他线程加一0
我加一完毕了+++++++++++++++++++++++++唤醒其他线程减一1
我减一完毕了--------------------------唤醒其他线程加一0
我加一完毕了+++++++++++++++++++++++++唤醒其他线程减一1
我减一完毕了--------------------------唤醒其他线程加一0
我加一完毕了+++++++++++++++++++++++++唤醒其他线程减一1
我减一完毕了--------------------------唤醒其他线程加一0
我加一完毕了+++++++++++++++++++++++++唤醒其他线程减一1
我减一完毕了--------------------------唤醒其他线程加一0
我加一完毕了+++++++++++++++++++++++++唤醒其他线程减一1
我减一完毕了--------------------------唤醒其他线程加一0
我加一完毕了+++++++++++++++++++++++++唤醒其他线程减一1
我减一完毕了--------------------------唤醒其他线程加一0
我减一完毕了--------------------------唤醒其他线程加一-1
我减一完毕了--------------------------唤醒其他线程加一-2
我减一完毕了--------------------------唤醒其他线程加一-3
我减一完毕了--------------------------唤醒其他线程加一-4
我加一完毕了+++++++++++++++++++++++++唤醒其他线程减一-3
我减一完毕了--------------------------唤醒其他线程加一-4
我减一完毕了--------------------------唤醒其他线程加一-5
我减一完毕了--------------------------唤醒其他线程加一-6
我减一完毕了--------------------------唤醒其他线程加一-7
我减一完毕了--------------------------唤醒其他线程加一-8
我减一完毕了--------------------------唤醒其他线程加一-9
我减一完毕了--------------------------唤醒其他线程加一-10
我减一完毕了--------------------------唤醒其他线程加一-11
我减一完毕了--------------------------唤醒其他线程加一-12
我加一完毕了+++++++++++++++++++++++++唤醒其他线程减一-11
我加一完毕了+++++++++++++++++++++++++唤醒其他线程减一-10
我加一完毕了+++++++++++++++++++++++++唤醒其他线程减一-9
我加一完毕了+++++++++++++++++++++++++唤醒其他线程减一-8
我加一完毕了+++++++++++++++++++++++++唤醒其他线程减一-7
我加一完毕了+++++++++++++++++++++++++唤醒其他线程减一-6
我加一完毕了+++++++++++++++++++++++++唤醒其他线程减一-5
我加一完毕了+++++++++++++++++++++++++唤醒其他线程减一-4
我加一完毕了+++++++++++++++++++++++++唤醒其他线程减一-3
比如说:当值为0时,2个加操作被唤醒了,同时执行如下代码,会造成加1加两次
if(number!=0){
//等待
this.wait();
}
number++;
但是如果改成如下判断,就只会执行一次加1
while(number!=0){
//等待
this.wait();
}
number++;
if 改为 while 判断
package com.zjl;
/**
* Created by zjl
* 2020/11/20
**/
/*
* 1、线程之间的通信问题:生产者和消费者问题!
* 2、线程交替执行,A B 操作同一个变量 num = 0
* 3、A num+1
* 4、B num-1
* */
public class Test {
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();
}
}
}).start();
new Thread(()->{
for (int i = 0; i < 10; i++) {
try {
data.decrement();
} catch (InterruptedException e) {
e.printStackTrace();
}
}
}).start();
new Thread(()->{
for (int i = 0; i < 10; i++) {
try {
data.increment();
} catch (InterruptedException e) {
e.printStackTrace();
}
}
}).start();
new Thread(()->{
for (int i = 0; i < 10; i++) {
try {
data.decrement();
} catch (InterruptedException e) {
e.printStackTrace();
}
}
}).start();
}
}
//等待-----》业务-----》通知
class Data{ //数字,资源类
private int number = 0;
//+1
public synchronized void increment() throws InterruptedException {
while (number!=0){
//等待
this.wait();
}
number++;
System.out.println("我加一完毕了+++++++++++++++++++++++++唤醒其他线程减一" + number);
this.notifyAll();
}
//-1
public synchronized void decrement() throws InterruptedException {
while (number == 0){
//等待
this.wait();
}
number--;
System.out.println("我减一完毕了--------------------------唤醒其他线程加一" + number);
this.notifyAll();
}
}
执行结果
/Library/Java/JavaVirtualMachines/jdk1.8.0_231.jdk/Contents/Home/bin/java "-javaagent:/Users/zhangjianlong/Library/Application Support/JetBrains/Toolbox/apps/IDEA-U/ch-0/193.5662.53/IntelliJ IDEA.app/Contents/lib/idea_rt.jar=59913:/Users/zhangjianlong/Library/Application Support/JetBrains/Toolbox/apps/IDEA-U/ch-0/193.5662.53/IntelliJ IDEA.app/Contents/bin" -Dfile.encoding=UTF-8 -classpath /Library/Java/JavaVirtualMachines/jdk1.8.0_231.jdk/Contents/Home/jre/lib/charsets.jar:/Library/Java/JavaVirtualMachines/jdk1.8.0_231.jdk/Contents/Home/jre/lib/deploy.jar:/Library/Java/JavaVirtualMachines/jdk1.8.0_231.jdk/Contents/Home/jre/lib/ext/cldrdata.jar:/Library/Java/JavaVirtualMachines/jdk1.8.0_231.jdk/Contents/Home/jre/lib/ext/dnsns.jar:/Library/Java/JavaVirtualMachines/jdk1.8.0_231.jdk/Contents/Home/jre/lib/ext/jaccess.jar:/Library/Java/JavaVirtualMachines/jdk1.8.0_231.jdk/Contents/Home/jre/lib/ext/jfxrt.jar:/Library/Java/JavaVirtualMachines/jdk1.8.0_231.jdk/Contents/Home/jre/lib/ext/localedata.jar:/Library/Java/JavaVirtualMachines/jdk1.8.0_231.jdk/Contents/Home/jre/lib/ext/nashorn.jar:/Library/Java/JavaVirtualMachines/jdk1.8.0_231.jdk/Contents/Home/jre/lib/ext/sunec.jar:/Library/Java/JavaVirtualMachines/jdk1.8.0_231.jdk/Contents/Home/jre/lib/ext/sunjce_provider.jar:/Library/Java/JavaVirtualMachines/jdk1.8.0_231.jdk/Contents/Home/jre/lib/ext/sunpkcs11.jar:/Library/Java/JavaVirtualMachines/jdk1.8.0_231.jdk/Contents/Home/jre/lib/ext/zipfs.jar:/Library/Java/JavaVirtualMachines/jdk1.8.0_231.jdk/Contents/Home/jre/lib/javaws.jar:/Library/Java/JavaVirtualMachines/jdk1.8.0_231.jdk/Contents/Home/jre/lib/jce.jar:/Library/Java/JavaVirtualMachines/jdk1.8.0_231.jdk/Contents/Home/jre/lib/jfr.jar:/Library/Java/JavaVirtualMachines/jdk1.8.0_231.jdk/Contents/Home/jre/lib/jfxswt.jar:/Library/Java/JavaVirtualMachines/jdk1.8.0_231.jdk/Contents/Home/jre/lib/jsse.jar:/Library/Java/JavaVirtualMachines/jdk1.8.0_231.jdk/Contents/Home/jre/lib/management-agent.jar:/Library/Java/JavaVirtualMachines/jdk1.8.0_231.jdk/Contents/Home/jre/lib/plugin.jar:/Library/Java/JavaVirtualMachines/jdk1.8.0_231.jdk/Contents/Home/jre/lib/resources.jar:/Library/Java/JavaVirtualMachines/jdk1.8.0_231.jdk/Contents/Home/jre/lib/rt.jar:/Library/Java/JavaVirtualMachines/jdk1.8.0_231.jdk/Contents/Home/lib/ant-javafx.jar:/Library/Java/JavaVirtualMachines/jdk1.8.0_231.jdk/Contents/Home/lib/dt.jar:/Library/Java/JavaVirtualMachines/jdk1.8.0_231.jdk/Contents/Home/lib/javafx-mx.jar:/Library/Java/JavaVirtualMachines/jdk1.8.0_231.jdk/Contents/Home/lib/jconsole.jar:/Library/Java/JavaVirtualMachines/jdk1.8.0_231.jdk/Contents/Home/lib/packager.jar:/Library/Java/JavaVirtualMachines/jdk1.8.0_231.jdk/Contents/Home/lib/sa-jdi.jar:/Library/Java/JavaVirtualMachines/jdk1.8.0_231.jdk/Contents/Home/lib/tools.jar:/Users/zhangjianlong/testCode/JUC-study/target/classes:/Users/zhangjianlong/apache-maven-3.6.3/repository/org/projectlombok/lombok/1.18.8/lombok-1.18.8.jar com.zjl.Test
我加一完毕了+++++++++++++++++++++++++唤醒其他线程减一1
我减一完毕了--------------------------唤醒其他线程加一0
我加一完毕了+++++++++++++++++++++++++唤醒其他线程减一1
我减一完毕了--------------------------唤醒其他线程加一0
我加一完毕了+++++++++++++++++++++++++唤醒其他线程减一1
我减一完毕了--------------------------唤醒其他线程加一0
我加一完毕了+++++++++++++++++++++++++唤醒其他线程减一1
我减一完毕了--------------------------唤醒其他线程加一0
我加一完毕了+++++++++++++++++++++++++唤醒其他线程减一1
我减一完毕了--------------------------唤醒其他线程加一0
我加一完毕了+++++++++++++++++++++++++唤醒其他线程减一1
我减一完毕了--------------------------唤醒其他线程加一0
我加一完毕了+++++++++++++++++++++++++唤醒其他线程减一1
我减一完毕了--------------------------唤醒其他线程加一0
我加一完毕了+++++++++++++++++++++++++唤醒其他线程减一1
我减一完毕了--------------------------唤醒其他线程加一0
我加一完毕了+++++++++++++++++++++++++唤醒其他线程减一1
我减一完毕了--------------------------唤醒其他线程加一0
我加一完毕了+++++++++++++++++++++++++唤醒其他线程减一1
我减一完毕了--------------------------唤醒其他线程加一0
我加一完毕了+++++++++++++++++++++++++唤醒其他线程减一1
我减一完毕了--------------------------唤醒其他线程加一0
我加一完毕了+++++++++++++++++++++++++唤醒其他线程减一1
我减一完毕了--------------------------唤醒其他线程加一0
我加一完毕了+++++++++++++++++++++++++唤醒其他线程减一1
我减一完毕了--------------------------唤醒其他线程加一0
我加一完毕了+++++++++++++++++++++++++唤醒其他线程减一1
我减一完毕了--------------------------唤醒其他线程加一0
我加一完毕了+++++++++++++++++++++++++唤醒其他线程减一1
我减一完毕了--------------------------唤醒其他线程加一0
我加一完毕了+++++++++++++++++++++++++唤醒其他线程减一1
我减一完毕了--------------------------唤醒其他线程加一0
我加一完毕了+++++++++++++++++++++++++唤醒其他线程减一1
我减一完毕了--------------------------唤醒其他线程加一0
我加一完毕了+++++++++++++++++++++++++唤醒其他线程减一1
我减一完毕了--------------------------唤醒其他线程加一0
我加一完毕了+++++++++++++++++++++++++唤醒其他线程减一1
我减一完毕了--------------------------唤醒其他线程加一0
我加一完毕了+++++++++++++++++++++++++唤醒其他线程减一1
我减一完毕了--------------------------唤醒其他线程加一0
Process finished with exit code 0