JVM调优
栈的内存要远远小于堆内存
-Xss
选项设置栈内存的大小。
-Xms
选项可以设置堆的开始时的大小,-Xmx选项可以设置堆的最大值。
锁(lock、synchronized)
在Java中,每一个对象都拥有一个锁标记(锁),也称为监视器,多线程同时访问某个对象时,线程只有获取了该对象的锁才能访问。
Lock和synchronized有以下几点不同:
1)Lock是一个接口,而synchronized是Java中的关键字,synchronized是内置的语言实现;
2)采用synchronized不需要用户去手动释放锁,当synchronized方法或者synchronized代码块执行完后,系统会自动让线程释放对锁的占用;synchronized在发生异常时,会自动释放线程占有的锁,因此不会导致死锁现象发生;而Lock在发生异常时,如果没有主动通过unLock()去释放锁,则很可能造成死锁现象,因此使用Lock时需要在finally块中释放锁;
3)响应中断Lock可以让等待锁的线程响应中断,而synchronized却不行,使用synchronized时,等待的线程会一直等待下去,不能够响应中断;
4)Lock可以是否获取锁,synchronized不行。
5)Lock可以提高多个线程进行读操作的效率。
6)公平锁Lock可以设置为公平锁,synchronized就是非公平锁
单独调用interrupt()方法不能中断正在运行过程中的线程,只能中断阻塞过程中的线程。
当通过lockInterruptibly()方法获取某个锁时,如果不能获取到,只有进行等待的情况下,是可以响应中断的(线程B调用threadB.interrupt()方法能够中断线程B的等待过程)。
而用synchronized修饰的话,当一个线程处于等待某个锁的状态,是无法被中断的,只有一直等待下去。
网友评论