synchronized修饰静态方法和普通方法的区别

synchronized具有同步功能,是一种互斥锁,锁的是对象,synchronized修饰普通方法时,锁对象是this对象。修饰静态方法时,锁对象是字节码文件对象。
synchronized可以用来修饰代码块和方法。
synchronized可以保证原子性,有序性,可见性。

synchronized的缺点:
1、synchronized底层是由jvm实现,因此不能手动控制锁的释放,不如lock锁灵活,synchronized修饰的方法一旦出现异常,jvm保证锁会被释放(lock锁需要在finally中释放)。
2、synchronized是非公平锁,不保证公平性。

synchronized修饰普通方法

public synchronized void run()  {
    System.out.println(1);
    try {
        Thread.sleep(1000);
    } catch (InterruptedException e) {
        e.printStackTrace();
    }
    System.out.println(2);
}

使用同一对象访问

Demo demo = new Demo();
new Thread(() -> demo.run()).start();
new Thread(() -> demo.run()).start();

那么结果是同步的
在这里插入图片描述
如果使用不同的对象访问

Demo demo = new Demo();
new Thread(() -> demo.run()).start();
Demo demo2 = new Demo();
new Thread(() -> demo2.run()).start();

那么结果是不同步的,因为synchronized修饰普通方法时锁对象是this对象,而使用两个对象去访问,不是同一把锁,当然不会同步。

在这里插入图片描述

synchronized修饰静态方法

public static synchronized void run()  {
    System.out.println(1);
    try {
        Thread.sleep(1000);
    } catch (InterruptedException e) {
        e.printStackTrace();
    }
    System.out.println(2);
}

使用不同的对象访问

	Demo demo = new Demo();
    new Thread(() -> demo.run()).start();
    Demo demo2 = new Demo();
    new Thread(() -> demo2.run()).start();

可以看到结果是同步的,因为当修饰静态方法时,锁对象是class字节码文件对象,而两个对象是同一个class文件,所以使用的是一个锁。

在这里插入图片描述

猜你喜欢

转载自blog.csdn.net/ROAOR1/article/details/88845700