可能的解决办法
多线程时控制台输出乱序的问题_Veiko的博客-优快云博客
/**
* @ClassName Test11
* @Author bugis
* @Date 2021/6/24 0:07
* @Version 1.0
**/
/*
启动3个线程打印递增的数字, 线程1先打印1,2,3,4,5,
然后是线程2打印6,7,8,9,10, 然后是线程3打印11,12,13,14,15.
接着再由线程1打印16,17,18,19,20….以此类推, 直到打印到75。
效果图如下:
1线程 1,2,3,4,5 16,17,18,19,20 31 32 33 34 35
2线程 6 7 8 9 10 21 22 23 24 25
3号线程 11 12 13 14 15 26 27 28 29 30
1<num<5 就让1号线程运行,让2,3等待,一号线程运行完,唤醒2,3号线程
6<num<10 就让2线程运行,让1,3等待,2号线程运行完,唤醒1,3号线程
16<num<20 就让1号线程运行,让2,3等待,一号线程运行完,唤醒2,3号线程
算法就是 1<num<5 num/5=0 和 16<num<20 num/5=3 和 31<num<35 num/5=6 和 1 产生联系
6<num<10 num/5%3+1=2 和 21<num<25 num/5%3+1=2 和 2 产生联系
num/5%3=0 0%3=0 1 num/5=3 3%3=0 1 num/5=6 6%3=0 1
num/5%3+1=id
*/
public class Test11 {
public static void main(String[] args) {
//创建三个目标(三个目标打印的是1-75[共享的]),每个目标创建一个线程
//要为每个目标创建一个标识
new Thread(new PrintNum(1)).start();
new Thread(new PrintNum(2)).start();
new Thread(new PrintNum(3)).start();
//如果你把目标对象提出来 只建一个的话就不用加static了 想要给每个线程起一个标识(id)
// 如果标识想要创建到线程名称的时候,可以采用将目标对象提取出来了
//既然这样为啥不用继承... 用继承是可以的
}
}
class PrintNum implements Runnable{
int id;
static int num=1;
public PrintNum(int id) {
this.id = id;
}
@Override
public void run() {
while(num<=75){
// System.out.println ("-----------------------门口等待"+id);//左边的语句添加进去口可能会锁不住
synchronized (this.getClass()) {//可以的
// System.out.println("-----------------------进入锁的"+id);//左边的语句添加进去口可能会锁不住
if(num/5%3+1==id){//符合条件的线程进入if
System.out.println("---------------"+id+"号线程--------------");
for (int i = 0; i < 5; i++) {
System.out.print(num+" ");
num++;
}
System.out.println();//作用就是换行
//当前线程打印完毕后,唤醒所有线程
this.getClass().notifyAll();
}else{//不符合条件的线程进入else,就立刻进入等待状态
try {
this.getClass().wait();
} catch (InterruptedException e) {
e.printStackTrace();
}
}
}
}
}
}
问题描述:
创建三个线程对象(用数字代替)1,2,3。
分别让三个线程依次打印到控制台:
线1 线2 线3
1 - 5 6-10 11-15
16-20 21-25 26-30
--------- 70-75
当在synchronized代码上下添加输出语句后,可能会锁不住。
输出结果如下:
D:\Java\jdk1.8.0_141\bin\java.exe "-javaagent:C:\AA\IntelliJ IDEA 2019.2.2\lib\idea_rt.jar=62863:C:\AA\IntelliJ IDEA 2019.2.2\bin" -Dfile.encoding=UTF-8 -classpath D:\Java\jdk1.8.0_141\jre\lib\charsets.jar;D:\Java\jdk1.8.0_141\jre\lib\deploy.jar;D:\Java\jdk1.8.0_141\jre\lib\ext\access-bridge-64.jar;D:\Java\jdk1.8.0_141\jre\lib\ext\cldrdata.jar;D:\Java\jdk1.8.0_141\jre\lib\ext\dnsns.jar;D:\Java\jdk1.8.0_141\jre\lib\ext\jaccess.jar;D:\Java\jdk1.8.0_141\jre\lib\ext\jfxrt.jar;D:\Java\jdk1.8.0_141\jre\lib\ext\localedata.jar;D:\Java\jdk1.8.0_141\jre\lib\ext\nashorn.jar;D:\Java\jdk1.8.0_141\jre\lib\ext\sunec.jar;D:\Java\jdk1.8.0_141\jre\lib\ext\sunjce_provider.jar;D:\Java\jdk1.8.0_141\jre\lib\ext\sunmscapi.jar;D:\Java\jdk1.8.0_141\jre\lib\ext\sunpkcs11.jar;D:\Java\jdk1.8.0_141\jre\lib\ext\zipfs.jar;D:\Java\jdk1.8.0_141\jre\lib\javaws.jar;D:\Java\jdk1.8.0_141\jre\lib\jce.jar;D:\Java\jdk1.8.0_141\jre\lib\jfr.jar;D:\Java\jdk1.8.0_141\jre\lib\jfxswt.jar;D:\Java\jdk1.8.0_141\jre\lib\jsse.jar;D:\Java\jdk1.8.0_141\jre\lib\management-agent.jar;D:\Java\jdk1.8.0_141\jre\lib\plugin.jar;D:\Java\jdk1.8.0_141\jre\lib\resources.jar;D:\Java\jdk1.8.0_141\jre\lib\rt.jar;D:\IdeaProjects\bigdata0523\out\production\day23 com.atguigu.test1.Test11
-----------------------门口等待1
-----------------------进入锁的1
-----------------------门口等待3
-----------------------门口等待2
---------------1号线程--------------
1 2 3 4 5
-----------------------门口等待1
-----------------------进入锁的2
---------------2号线程--------------
6 7 8 9 10
-----------------------门口等待2
-----------------------进入锁的3
---------------3号线程--------------
11 12 13 14 15
-----------------------门口等待3
-----------------------进入锁的3
-----------------------进入锁的2
-----------------------进入锁的1
---------------1号线程--------------
16 17 18 19 20
-----------------------门口等待1
-----------------------门口等待3
-----------------------门口等待2
-----------------------进入锁的1
-----------------------进入锁的2
---------------2号线程--------------
21 22 23 24 25
-----------------------门口等待2
-----------------------进入锁的2
-----------------------进入锁的3
---------------3号线程--------------
26 27 28 29 30
-----------------------门口等待3
-----------------------进入锁的3
-----------------------门口等待1
-----------------------门口等待2
-----------------------进入锁的1
---------------1号线程--------------
31 32 33 34 35
-----------------------门口等待1
-----------------------进入锁的2
-----------------------门口等待3
---------------2号线程--------------
36 37 38 39 40
-----------------------门口等待2
-----------------------进入锁的3
---------------3号线程--------------
41 42 43 44 45
-----------------------门口等待3
-----------------------进入锁的1
---------------1号线程--------------
46 47 48 49 50
-----------------------门口等待1
-----------------------进入锁的3
-----------------------进入锁的2
---------------2号线程--------------
51 52 53 54 55
-----------------------门口等待2
-----------------------进入锁的1
-----------------------门口等待3
-----------------------进入锁的2
-----------------------进入锁的3
---------------3号线程--------------
56 57 58 59 60
-----------------------门口等待3
-----------------------门口等待1
-----------------------进入锁的3
-----------------------门口等待2
-----------------------进入锁的1
---------------1号线程--------------
61 62 63 64 65
-----------------------门口等待1
-----------------------进入锁的2
---------------2号线程--------------
66 -----------------------门口等待3 //********************************个人认为的没锁住
67 68 69 70
-----------------------门口等待2
-----------------------进入锁的3
---------------3号线程--------------
71 72 73 74 75
-----------------------进入锁的1
---------------1号线程--------------
76 77 78 79 80
-----------------------进入锁的2
---------------2号线程--------------
81 82 83 84 85
进程已结束,退出代码 0