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


synchronized同步锁机制

 

定义锁🔒的方式一:

package android.java.thread09;

public class Test implements Runnable {

  /**
   * 定义一个锁🔒,此锁🔒是共享的,这个锁是Java内部要去判断用的,属于隐士的 看不到的
   * Java内部的实现属于 🔒锁机制
   */
   Object lock = new Object();
    
    @Override
    public void run() {

        synchronized (lock) {
            /**
             * 多线程操作共享数据
             * 重复执行引发的问题
             * ...........
             */
        }

    }
}

 

定义锁🔒的方式二:

package android.java.thread09;

public class Test2 implements Runnable {

    @Override
    public void run() {

        /** Test2.class 认为是一个锁🔒,Test2.class是共享的锁🔒,这个锁是Java内部要去判断用的,属于隐士的 看不到的
         *  Java内部的实现属于 🔒锁机制
         */
        synchronized (Test2.class) {
            /**
             * 多线程操作共享数据
             * 重复执行引发的问题
             * ...........
             */
        }

    }
}

 

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

 


 

 

举例:高铁上的厕所:

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

 

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

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

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

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

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

 

 


 

 

synchronized同步代码块利与弊

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

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

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

 


免责声明!

本站转载的文章为个人学习借鉴使用,本站对版权不负任何法律责任。如果侵犯了您的隐私权益,请联系本站邮箱yoyou2525@163.com删除。



 
粤ICP备18138465号  © 2018-2025 CODEPRJ.COM