Android-Java-synchronized同步锁机制&利与弊

synchronized同步锁机制

技术分享图片

 

定义锁??的方式一:

package android.java.thread09;public class Test implements Runnable { @Override public void run() { /** * 定义一个锁??,这个锁是Jav内部要去判断用的,属于隐士的 看不到的 * Java内部的实现属于 ??锁机制 */ Object lock = new Object(); synchronized (lock) { /** * 多线程操作共享数据 * 重复执行引发的问题 * ........... */ } }}

 

定义锁??的方式二:

package android.java.thread09;public class Test2 implements Runnable { @Override public void run() { /** Test2.class 认为是一个锁??,这个锁是Jav内部要去判断用的,属于隐士的 看不到的 * Java内部的实现属于 ??锁机制 */ synchronized (Test2.class) { /** * 多线程操作共享数据 * 重复执行引发的问题 * ........... */ } }}

 

定义锁??的方式 ......    还有很多方式

 


 

 

举例:高铁上的厕所:

1.厕所门显示无人,高铁上有五个人,这五个人谁先进去(代表谁被CPU执行了)

 

     synchronized (厕所门显示无人 ??) { // 上厕所任务 ........ }

2.厕所门显示有人,高铁上有五个人,进去了一个人,进去的这个人一旦进去就会把门??上,其他四个人在门外等着,进不去

     synchronized (厕所门显示有人 ??) { // 上厕所任务 ........ }

3.进去的哪个人,上完厕所了,锁就打开了,厕所门上显示无人,  其他四个人谁先进去(主要看CPU执行权在哪个线程上执行)

     synchronized (厕所门显示无人 ??) { // 上厕所任务 ........ } 上完厕所了,锁就打开??,厕所门上显示无人

 

技术分享图片

 


 

 

synchronized同步代码块利与弊

1.好处是:synchronized同步代码,解决安全问题。

2.坏处是:每次都需要判断synchronized(的??是否 锁住),有点耗性能;

总结:1.完全问题解决,   2.有点耗性能,  当然选择1.完全问题解决

 

相关文章