lock和synchronized的区别:

package com.dongmu.test;

import java.util.concurrent.locks.Lock;
import java.util.concurrent.locks.ReentrantLock;

public class Test01 {
    public static void main(String[] args) {
        /*获得CPU的核数*/
//        System.out.println(Runtime.getRuntime().availableProcessors());
//        System.out.println(5>>2);
//
        Ticket ticket = new Ticket();
        new Thread(()->{
            for (int i = 0; i < 50; i++) {
                ticket.sale();
            }
        }).start();
        new Thread(()->{
            for (int i = 0; i < 50; i++) {
                ticket.sale();
            }
        }).start();
        new Thread(()->{
            for (int i = 0; i < 50; i++) {
                ticket.sale();
            }
        }).start();

    }
}

class Ticket{
    private int ticket = 40;

    public synchronized void sale(){
        if (ticket>0){
            System.out.println("卖出了"+ticket+"号票。剩余"+--ticket+"张票。");
        }
    }
}


/*使用lock锁的方式实现多线程安全*/

class Test02{
    public static void main(String[] args) {
        System.out.println("使用了非公平锁");
        Ticket2 ticket = new Ticket2();
        new Thread(()->{
            for (int i = 0; i < 50; i++) {
                ticket.sale();
            }
        }).start();
    }
}

class Ticket2{
    private int ticket = 40;

    Lock lock = new ReentrantLock();

    public void sale(){
        try{
            lock.lock();
            if (ticket>0){
                System.out.println("卖出了"+ticket+"号票。剩余"+--ticket+"张票..。");
            }
        }catch (Exception e){
            e.printStackTrace();
        }finally {
            lock.unlock();
        }
    }
}
lock和synchronized的区别:
	1)Lock是一个接口,而synchronized是Java中的关键字,synchronized是内置的语言实现;

  2)synchronized在发生异常时,会自动释放线程占有的锁,因此不会导致死锁现象发生;而Lock在发
  生异常时,如果没有主动通过unLock()去释放锁,则很可能造成死锁现象,因此使用Lock时需要在
  finally块中释放锁;

  3)Lock可以让等待锁的线程响应中断,而synchronized却不行,使用synchronized时,等待的线程
  会一直等待下去,不能够响应中断;

  4)通过Lock可以知道有没有成功获取锁,而synchronized却无法办到。

  5)Lock可以提高多个线程进行读操作的效率。

  在性能上来说,如果竞争资源不激烈,两者的性能是差不多的,而当竞争资源非常激烈时(即有大量线程同时竞争),此时Lock的性能要远远优于synchronized。所以说,在具体使用时要根据适当情况选择。
上一篇:并行与并发


下一篇:数据库-锁机制-通俗易懂介绍