找到问题了,我在excepTest方法中抛出异常,然后该方法上抛了异常
该异常被抛给了run方法,应该在run方法内处理该问题
但是代码中的查找捕获却在main方法中,肯定捕获不到异常
修正后代码:
class Test22_05 implements Runnable{
public void run() {
for(int i = 0; i < 10; i++){
try{
this.excepTest(i);
}catch(Exception e){
System.out.println(Thread.currentThread().getName() + "出现异常:" + e);
}
System.out.println(Thread.currentThread().getName() + ":i = " + i);
}
}
public void excepTest(int i)throws Exception{
if(i == 8){
throw new Exception("这是手动抛出异常!");
}
}
}
public class JavaTest22_05{
public static void main(String args[]){
Test22_05 t1 = new Test22_05();
Thread tt1 = new Thread(t1);
Thread tt2 = new Thread(t1);
Thread tt3 = new Thread(t1);
tt1.setName("线程1");
tt2.setName("线程2");
tt3.setName("线程3");
tt1.start();
tt2.start();
tt3.start();
tt1.start(); //本行将报错,因为线程只能启动一次
}
}
//本例中是将上抛异常和捕获异常写到多线程代码里面
//目的是实现当i为8时手动抛出异常
//基本上实现了,但是不知道为什么,三个线程处理了30条记录,不符合Runnable接口的共享资源特征
//将在JavaTest22_06.java中重写程序,试图找出问题。