解决线程不安全问题(synchronized)

1.synchronized
.当线程释放锁时,JMM会把该线程对应的工作内存中的共享变量刷新到主内存中
.当线程获取锁时,JMM会把该线程对应的本地内存置为无效。从而使得被监视器保护的临界区代码必须从主内存中读取共享变量
synchronized用的锁是存在Java对象头里的。解决多个线程访问时出现互相干扰的问题,被synchronized修饰的方法或代码块,在同一时刻,只会有一个 获得锁 的线程执行操作,其他线程都处于阻塞状态.
具体:
解决线程不安全问题(synchronized)
1.修饰实例方法
解决线程不安全问题(synchronized)
调用实例方法就要创建一个对应的对象,锁的也就是当前的实例对象, 所以如果是同一个对象调用,则会产生同步互斥,否则不会产生同步互斥
例如;
解决线程不安全问题(synchronized)

2.修饰静态方法:
解决线程不安全问题(synchronized)
静态方法不属于任何一个实例变量,是类成员,因此可以通过class对象锁控制静态成员的并发操作.由于获得的锁是当前class类对象锁,只有一个,所以会产生同步互斥.
3.同步代码块
解决线程不安全问题(synchronized)
synchronized作用于一个给定的实例对象,每次线程进入synchronized代码块时,会"抢锁",