锁的重入

简介: 锁的重入package demo;/* * synchronized的重入 * 关键字synchronized拥有锁重入得功能, * 当一个线程得到了一个对象的锁后,再次请求次对象时时可以再次得到该对象的锁。

锁的重入

package demo;

/*  
 * synchronized的重入
 * 关键字synchronized拥有锁重入得功能,
 * 当一个线程得到了一个对象的锁后,再次请求次对象时时可以再次得到该对象的锁。
 * 
 * 
 * 
 * */
public class MyDubbo {

    //在synchronized 方法一种调用synchronized 方法2,
    //方法2中又调用方法3
    public synchronized void method1(){
        System.out.println("method1....");
        method2();
    }

    public synchronized void method2(){
        System.out.println("method2....");
        method3();
    }

    public synchronized void method3(){
        System.out.println("method3....");
    }

    public static void main(String[] args) {

        final MyDubbo my1 = new MyDubbo();
        Thread t1 = new Thread(new Runnable() {

            @Override
            public void run() {
                my1.method1();
            }
        });

        //synchronized的重入  表面上看是三个方法都synchronized,以为要method1执行获取锁对象后,
        //执行完毕后,method2才能获取锁对象。事实不是这样的,synchronized重入
        //将三个方法的synchronized都去掉,结果一样,但是机制不一样。
        t1.start();
    }
}

子父类的重入

package demo;

/*
 * 子类父类之间的重入是可行的。
 * 
 *  重入得异常的捕捉。一定要考虑整体问题,处理异常。
 * */
public class MyDubbo2 {

    static class Main{
        public int num = 10 ;
        public synchronized void operationMainSup(){

            try {
                num--;
                System.out.println("Main print num = " + num );
                Thread.sleep(100);

            } catch (InterruptedException e) {
                e.printStackTrace();
            }
        }
    }

    static class Sub extends Main{
        public synchronized void operationSubSup() {
            try {
                while(num>0){
                    num--;
                    System.out.println("Sub print num = " + num );
                    Thread.sleep(100);
                    //父类中的方法
                    this.operationMainSup();
                }
            } catch (InterruptedException e) {
                e.printStackTrace();
            }
        }
    }

    public static void main(String[] args) {
        Thread t1 = new Thread(new Runnable() {
            @Override
            public void run() {
                Sub sub = new Sub();
                sub.operationSubSup();
            }
        });

        //开始线程
        t1.start();
    }
}
相关文章
|
3月前
|
SQL 关系型数据库 MySQL
MySQL使用行级锁时,并非直接锁定记录,而是锁定涉及的索引。对于表`user_item`,更新语句先锁定非主键索引`idx_1`,再锁定主键索引。若两条更新语句分别按不同顺序锁定这两个索引,可能导致互相等待对方释放锁,引发死锁。解决方案包括先查询待更新记录的主键,再按主键更新,确保一致的锁定顺序。
43 2
|
5月前
|
调度
线程操作:锁、条件变量的使用
线程操作:锁、条件变量的使用
28 1
|
5月前
|
Java 调度
阻塞锁和自旋锁的理解
总体来说,自旋锁适用于锁定时间短、锁竞争不频繁的场景,而阻塞锁更适合锁定时间较长或锁竞争较频繁的场景。根据具体的应用需求选择合适的锁类型,可以优化系统性能。
83 0
|
Linux API C++
锁、避免死锁等相关
锁、避免死锁等相关
67 0
《锁》有那些?
锁是计算机科学中用于控制对共享资源的访问的一种同步机制。不同种类的锁适用于不同的场景和需求。下面是一些常见的锁的种类及其详细介绍:
72 1
|
存储 算法 安全
辛辛苦苦的劳动成果,如何上把锁?
辛辛苦苦的劳动成果,如何上把锁?
|
数据可视化 Java
lock锁和死锁
lock锁和死锁
|
Java
各种锁的理解
各种锁的理解
118 0
各种锁的理解
|
生物认证
什么是锁?
什么是锁?
126 0
什么是锁?
锁总结
编程常用的算总结