一、是否选择锁
如果不存在多个线程操作共享变量,那么根本就无需锁
二、是否可以选择ThreadLocal
如果能用这个类解决,那么首先考虑这个。使用场景
三、乐观锁
乐观锁的核心就是自旋。现在很多类都是这个机制,AtomicXXX类的基本都是乐观锁的实现。
他的适用场景是锁的竞争不是很激烈的情况。
四、Synchronize可重入锁
这类锁会导致线程从用户态切换到内核态,所以是重量级锁。但是自从1.5之后synchronize关键字已经优化了好多,现在基本和ReentrentLock性能一致
4.1 Synchronize语义
他的实现核心是 monitorenter 和monitorexit指令。如果是liunx其实就是调用pthread来完成这些操作
4.2 锁的粗化
StringBuffer sb = new StringBuffer();
sb.append("1");
sb.append("2");
虽然StringBuffer 的方法都是被synchronize修饰,但是虚拟机会进行优化,其实就一次加锁
4.3 锁的消除
这个就必须说到对象逃逸:某个对象在方法内创建,并且并没有在返回结果中返回出去,就可以理解这个对象没有发生逃逸。
如果锁是没有逃逸的对象,那么完全可以锁消除
4.4 锁的自旋
一旦某个线程没有获取到锁,他不是直接就挂起,而是先不停的休眠,然后尝试,知道超过一定时间或者次数才会把自己挂起。