@Override程序员
public void test() {app
// xml配置ide
Vip vip = vipMapper.selectByPrimaryKey(31);函数
vip.setRemark("55事物");xml
vipMapper.updateByPrimaryKeySelective(vip);ip
int a = 1;io
if (a == 1) {编译
//int b=1/0; //出现的 是运行期异常 会回滚的test
try {监控
int b=1/0;
} catch (Exception e) {
System.out.println("异常了");//捕获了,并且没有抛出异常 就是, 编译期异常了,不会回滚的
throw new RuntimeException("hx_return is null");//抛出去 一个运行期异常才会回滚的
}
}
}
另外在代码中,只在方法内throw而没有在方法上声明throws,也能够编译经过的话,就是运行时异常(RuntimeException
中文意思以下:
1.运行时异常和编译时异常的区别 编译时异常要求对它进行显式的try..catch 捕获处理或者向上一层方法抛出,不然在编译期 间就显示错误.而运行时异常在编译阶段不予检查,语法上不会显示任何错误。 2.throws和throw的相同点和区别 区别: 1)throw 是手动抛出异常,throw new **Exception(); 抛出的是某一个异常类型的实例 2)throws 是方法抛出异常,写在方法声明处 public void show()throws **Exception.紧跟throws后的是异常类型,而非异常实例,且能够声明抛出多个异常,同时这些异常类型大多都为编译时异常类型。 3)throw 是程序员手动抛出异常,通常可用在某种流程控制,须要显示操做失误状况下可 对外抛出异常,进入catch代码块,明示操做有误等. 明确这个地方要抛出这个异常. 4)throws 方法抛出异常,一般是告知调用此方法者,本方法有可能抛出一个异常,在调用 时应当要进行异常监控。且由于throws方法抛出异常为编译时异常类型,这样在编译阶段就 要求用户调用时对编译时异常类型做出捕获[try..catch(){}语句块],或者再次向上抛出。 5)throws能够单独使用,但throw不能.throw要么和try-catch-finally语句配套使用,要么与throws配套使用。但throws能够单独使用,而后再由处理异常的方法捕获。 6)程序会在throw语句后当即终止,它后面的语句执行不到,而后在包含它的全部try块中 (可能在上层调用函数中)从里向外寻找含有与其匹配的catch子句的try块。 相同点: 只是抛出或者可能抛出异常,可是不会由函数去处理异常,真正的处理异常由函数的上层调 用处理。 3.如何对编译时异常进行处理 方法一:将须要处理的代码块放在一个try...catch...中 方法二:在出现异常的方法上 直接向上抛出异常 [能够一直继续向上抛 直到主函数向上抛到JVM处理]