目录
一、异常的捕获和处理
try{
try代码段中包含可能产生异常的代码,有人称为陷阱代码,
在执行过程中如果出现了异常,则异常之后的java语句不会
执行。转而执行catch部分的代码
} catch(SomeException e){ 可以写多个
try后可以跟一个多个catch代码段,针对不同异常执行不同
的处理逻辑。当异常发生时,程序会中止当前的流程,根据获
取异常的类型去执行响应的代码段。注意异常类型判定时是从
上向下逐个判断的。
}finally{
finally代码是无论是否发生异常都会执行的代码
}
二、基本用法
Integer kk=null;
try{
String str="123.456";
//由于str参数数据不合法,不是整数,所以这里异常NumberFormatException
kk=Integer.parseInt(str);
System.out.println("数据转换结束");//上句出现异常,这里就不会执行
} catch(Exception e){//出现异常后进行类型判断,如果是这种异常则执行这里的代码段
System.out.println("出现了错误:"+e.getMessage());
e.printStackTrace(); //在控制台上打印输出调用栈
}
System.out.println("转换结果为:"+kk);
三、OOM产生的原因
1、分配的少了:比如虚拟机本身可使用的内存(一般通过启动时的VM参数指定)太少
2、应用用的太多,并且用完没释放,浪费了。此时就会造成内存泄露或者内存溢出。
内存泄露:申请使用完的内存没有释放,导致虚拟机不能再次使用该内存,此时
这段内存就泄露了,因为申请者不用了,而又不能被虚拟机分配给别人用。
内存溢出:申请的内存超出了JVM能提供的内存大小,此时称之为溢出。
在Java语言中由于存在了垃圾自动回收机制,所以一般不用去主动释放不用的对象
所占的内存,也就是理论上来说,是不会存在内存泄露的。但是,如果编码不当,
比如将某个对象的引用放到了全局的Map中,虽然方法结束了,但是由于垃圾回收器
会根据对象的引用情况来回收内存,导致该对象不能被及时的回收。如果该种情况
出现次数多了,就会导致内存溢出,比如系统中经常使用的缓存机制。Java中的内存
泄露,不同于C++中的忘了delete,往往是逻辑上的原因泄露。
四、最常见的OOM情况有以下三种:
1、java.lang.OutOfMemoryError: Java heap space ------>java堆内存溢出,
此种情况最常见,一般由于内存泄露或者堆的大小设置不当引起。对于内存泄露,需
要通过内存监控软件查找程序中的泄露代码,而堆大小可以通过虚拟机参数-Xms,-Xmx
等修改。
2、java.lang.OutOfMemoryError: PermGen space ------>java永久代溢出,即
方法区溢出了,一般出现于大量Class或者jsp页面,或者采用cglib等反射机制的情况
,因为上述情况会产生大量的Class信息存储于方法区。此种情况可以通过更改方法区
的大小来解决,使用类似-XX:PermSize=64m -XX:MaxPermSize=256m的形式修改。另
外,过多的常量尤其是字符串也会导致方法区溢出。
3、java.lang.StackOverflowError ------> 不会抛OOM error,但也是比较常见
的Java内存溢出。JAVA虚拟机栈溢出,一般是由于程序中存在死循环或者深度递归调用
造成的,栈大小设置太小也会出现此种溢出。可以通过虚拟机参数-Xss来设置栈的大小。
五、throw 和throws
throw 人为编码抛出异常
- new RuntimeException()
- new RuntimeException("异常的提示信息");
throws--用在方法签名中,用于声明该方法可能抛出的异常,要求谁调用谁处理这个异常。
主方法上也可以使用throws抛出。如果在主方法上使用了throws抛出,就表示在主方法里面
可以不用强制性进行异常处理,如果出现了异常,就交给JVM进行默认处理,则此时会导致程
序中断执行。