reentrantlock 是可重入锁
(重进入是指任意线程在获取到锁之后能够再次获取该锁而不会被锁阻塞),
即一个线程 可以多次 获得该锁 (计数器 会加增加 释放时直到 计数器为 0 才表示 被释放完成 )
同时 支持 使用 非公平/公平 锁 (默认为 非公平 但是可能会造成 饥饿效应)
与 Synchronized的异同:
1.它们都是加锁方式同步;
2.都是重入锁;
3. 阻塞式的同步;也就是说当如果一个线程获得了对象锁,进入了同步块,其他访问该同步块的线程都必须阻塞在同步块外面等待,而进行线程阻塞和唤醒的代价是比较高的
这两种方式最大区别就是对于Synchronized来说,它是java语言的关键字,是原生语法层面的互斥,需要jvm实现。而ReentrantLock它是JDK 1.5之后提供的API层面的互斥锁,需要lock()和unlock()方法配合try/finally语句块来完成。