1.在JAVA 程序中怎么保证多线程的运行安全
- 使用安全类,比如 java.util.concurrent 下的类
- 使用自动锁 synchronized
- 使用手动锁 lock
示例代码:
Lock lock = new ReentrantLock();
lock.lock();
try {
System.out.println("获得锁");
} catch (Exception e) {
// TODO: handle exception
}finally{
System.out.println("释放锁");
lock.unlock();
}
2.什么是死锁?
线程A持有独占锁a,线程B持有独占锁b,当A尝试获取独占锁b同时,B尝试获取独占锁a的情况下,就会发生AB两个线程由于互相持有对方需要的锁,而发生阻塞的现象,我们称之为死锁。
3.怎么防止死锁?
- 尽量使用 tryLock(long time, TimeUnit unit) 的方法(ReentrantLock、ReentrantWriteLock),设置超时时间,超时可以退出防止死锁。
- 尽量使用java.util.concurrent 并发类代替自己手写锁。
- 尽量降低锁的使用粒度,尽量不要几个功能同用一把锁。
- 尽量减少同步的代码块。
4.ThreadLocal是什么?
ThreadLocal为每个使用该变量的线程提供独立的变量副本,所以每一个线程都可以独立的改变自己的副本,而不会影响其他线程所对应的副本。
ThreadLocal 的经典使用场景就是数据库链接和 seeeion管理等。