phone.sendSMS();
} catch (Exception e) {
e.printStackTrace();
}
}, “AA”).start();
Thread.sleep(100);
new Thread(() -> {
try {
phone.sendEmail();
//phone.getHello();
//phone2.sendEmail();
} catch (Exception e) {
e.printStackTrace();
}
}, “BB”).start();
}
}
复制代码
**2. 锁的8个问题**
(1) 标准访问,先打印短信还是邮件
(2) 停4秒在短信方法内,先打印短信还是邮件
(3) 普通的hello方法,是先打短信还是hello
(4) 现在有两部手机,先打印短信还是邮件
(5) 两个静态同步方法,1部手机,先打印短信还是邮件
(6) 两个静态同步方法,2部手机,先打印短信还是邮件
(7) 1个静态同步方法,1个普通同步方法,1部手机,先打印短信还是邮件
(8) 1个静态同步方法,1个普通同步方法,2部手机,先打印短信还是邮件
**3. 锁的8个问题分析**
一个对象里面如果有多个synchronized方法,某一个时刻内,只要一个线程去调用其中的一个synchronized方法了,其它的线程都只能等待,换句话说,某一个时刻内,只能有唯一一个线程去访问这些synchronized方法。
锁的是当前对象this,被锁定后,其它的线程都不能进入到当前对象的其它的synchronized方法。
加个普通方法后发现和同步锁无关。
换成两个对象后,不是同一把锁了,情况立刻变化。
synchronized实现同步的基础:Java中的每一个对象都可以作为锁。
具体表现为以下3种形式。
对于普通同步方法,锁是当前实例对象。
对于静态同步方法,锁是当前类的Class对象。
对于同步方法块,锁是Synchonized括号里配置的对象
当一个线程试图访问同步代码块时,它首先必须得到锁,退出或抛出异常时必须释放锁。
也就是说如果一个实例对象的非静态同步方法获取锁后,该实例对象的其他非静态同步方法必须等待获取锁的方法释放锁后才能获取锁,可是别的实例对象的非静态同步方法因为跟该实例对象的非静态同步方法用的是不同的锁,所以毋须等待该实例对象已获取锁的非静态同步方法释放锁就可以获取他们自己的锁。
![img](https://img-blog.csdnimg.cn/img_convert/cf3eee727225c24b3c427465f9d41970.png)
![img](https://img-blog.csdnimg.cn/img_convert/9e76467d2d1a21c02fa5c7d452c57c3b.png)
![img](https://img-blog.csdnimg.cn/img_convert/c7084b1e73da1fd42f4fbfccba0e1e6a.png)
**既有适合小白学习的零基础资料,也有适合3年以上经验的小伙伴深入学习提升的进阶课程,涵盖了95%以上大数据知识点,真正体系化!**
**由于文件比较多,这里只是将部分目录截图出来,全套包含大厂面经、学习笔记、源码讲义、实战项目、大纲路线、讲解视频,并且后续会持续更新**
**[需要这份系统化资料的朋友,可以戳这里获取](https://bbs.csdn.net/topics/618545628)**
项目、大纲路线、讲解视频,并且后续会持续更新**
**[需要这份系统化资料的朋友,可以戳这里获取](https://bbs.csdn.net/topics/618545628)**