关于finally语句块
1.finally语句块可以直接和try语句块联用:try…finally…
2.try…catch…finally也可以
3.finally语句块中的代码是一定会执行的,所以通常在程序中为了保证某资源一定会释放,所以一般在finally语句块中释放资源
public class Test{
public static void main(String[] args){
try{
System.out.println("Test01");
return ;
}finally{
Systemo.out.println("Tets02"); //Test01和Test02都会输出,由于有finally关键字,会先输出完Test02后再return返回
}
//分析以下代码,有FileInputStream出现,则会需要异常处理机制,但是有try没有catch,发生异常后会终止掉程序但是finally后面的语句还是会执行,所Test01不会输出,Test02会输出
try{
FileInputSream fis = new FileInputStream("c:/as.txt");
System.out.println("Test01");
}finally{
System.out.println("Test02");
}
//这种情况finally语句块不会执行,在执行finally之前退出了JVM
try{
//退出JVM
System.exit(0);
}finally{
System.out.println("Test02");
}
}
}
public class Test {
public static void main(String[] args) {
// TODO Auto-generated method stub
int x;
x =m1();
System.out.println(x);
}
public static int m1() {
int i = 10;
try {
//以下代码的原理是,引入一个临时变量,把该变量赋给她,然后return该临时变量
//int temp;
//temp = i;
//return temp;
return i;
}
finally {
i++;
System.out.println("i = "+i);
}
}
}
3.finally语句块中的代码是一定会执行的,所以通常在程序中为了保证某资源一定会释放,所以一般在finally语句块中释放资源
/*
finally的代码块一定会执行所以一般用他来释放资源,下面通过FileInputStream的例子,用finally来释放资源
FileInputStream要通过close()方法来释放资源,同时close()方法的异常处理类为IOException
*/
import java.io.*;
public class ExceptionTest {
public static void main(String[] args) {
// TODO Auto-generated method stub
FileInputStream fis =null;
try {
fis =new FileInputStream("c:/ab.txt");
}catch(FileNotFoundException e) {
String ms = e.getMessage();
System.out.println(ms);
}finally {
if(fis != null) { //下面代码不会执行,因为上面路径没有文件所以不会创建成功,所以fis还是一个null
try {
fis.close();
}catch(IOException s) {
s.printStackTrace();
}
}
}
}
}
(final finalize finally 区别)
在说区别的时候,先分别论述每一个的作用,如果每个之间有异同点再进行比较
1.final
final 可以修饰变量,可以修饰方法,可以修饰类,
修饰的成员变量要手动赋值
修饰的类无法被继承
修饰的方法无法被覆盖
final和static连用定义常量,常量用大写表示
2.finalize
finalize是Object类中的一种方法,在垃圾回收机制回收垃圾对象之前,会先调用类中的finalize方法
3.finally
finally是一个语句块