谈谈多线程
多线程和死锁
其实对于死锁,很多人会望而生畏。而事实上,死锁的原理非常之简单。死锁的本质就是,A对象占据了资源x,B也差不多同时占用了资源y。在x和y资源都没有释放的时候,A和B试图申请资源y和x。于是A在等B释放y,B在等A释放x。更直白一点,一个男人和女人相互暗恋,男人想要女的先示爱,他才向女的表白,女的想要男的先表白,她才向男的示爱。于是就一直等下去。相信有很多人对于多线程或者是数据库操作一想到死锁,就感到忐忑,生怕一不小心就会死锁。其实也大可不必过于担忧,从上面的解释,死锁产生的前提条件有:
1,同时性。
2,有两个以上对象,可以理解为多个线程。
3,有两个以上资源,也就是锁。特别是第三点,对同一个资源的操作,是不可能产生死锁的。理解了死锁的本质之后,再进行扩展,就很清晰了。例如多线程会产生死锁,多个进程也可能产生死锁。多个数据库的会话也可能产生死锁。集群中多个服务器,也可能产生死锁。但万变不离其宗。
多线程和异常
模拟创建普通异常,运行的结果是,catch里面的代码不会执行,也就是说主线程捕获不了子线程的异常。因为这里比较明显看到了线程的创建。而在其它地方比较隐蔽,明明进行了try...catch,却没有捕获到想要的异常。
public static void fun1(){
List<Job> jobs= Arrays.asList(new Job(1),new Job(2),new Job(),new Job(3),new Job(4),new Job(5));
try {
Thread thread=new Thread(
() -> jobs.forEach(job -> job.work())
);
thread.start();
}catch (Exception e){
System.out.println("捕捉到异常"+e.getMessage());
}
}