多线程里在锁对象前后添加输出到控制台的语句,可能会并行的问题

可能的解决办法
多线程时控制台输出乱序的问题_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

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值