final finally finalize

final

//如果不是final 的话,我可以在checkInt方法内部把i的值改变(有意或无意的,

//虽然不会改变实际调用处的值),特别是无意的,可能会引用一些难以发现的BUG

publicstaticvoid checkInt(int i)

{

i = 200;//这样是可以的,不会编译出错的

//do something

}

//如果是final 的话,我可以在checkInt方法内部就没办法把i的值改变

//可以完全避免上面的问题

publicstaticvoid checkInt(finalint i)

{

i = 200;//这样是不可以的,会编译出错的

//do something

}

//final 的引用类型方法参数

publicstaticvoid checkLoginInfo(final LoginInfo login)

{

login = new LoginInfo();//error,编译不过去

//do something

}

//非final的引用类型方法参数

publicstaticvoid checkLoginInfo(LoginInfo login)

{

//没有任何问题,但是肯定不符合此参数存在的初衷

login = new LoginInfo();

//do something

}



在方法参数前面加final关键字就是为了防止数据在方法体中被修改。

主要分两种情况:第一,用final修饰基本数据类型;第二,用final修饰引用类型。

第一种情况,修饰基本类型(非引用类型)。这时参数的值在方法体内是不能被修改的,即不能被重新赋值。否则编译就通不过。例如:

1 public static void valid(final int ag){
2         ag=9;
3         ag=10;
4 }

错误提示:

第二种情况,修饰引用类型。这时参数变量所引用的对象是不能被改变的。作为引用的拷贝,参数在方法体里面不能再引用新的对象。否则编译通不过。例如:

1 public static void valid(final String[] ag){
2         ag=new String[9];
3 }

这个的提示和上面是一样的。:“ The final local variable param2 cannot be assigned. It must be blank and not using a compound assignment.“

但是对于引用,如果我是这样,则不会报任何错,完全能编译通过。但是运行会报错

1 public static void valid(final String[] ag){
2         ag[0]="5";
3         System.out.println(ag);
4 }

所以,final这个关键字,想用的话就用基本类型,还是很有作用的。

finally

与其他语言的模型相比,finally 关键字是对 Java 异常处理模型的最佳补充。finally 结构使代码总会执行,而不管有无异常发生。使用 finally 可以维护对象的内部状态,并可以清理非内存资源。 如果没有 finally,您的代码就会很费解。例如,下面的代码说明,在不使用 finally 的情况下您必须如何编写代码来释放非内存资源:

import java.net.*; 
import java.io.*;

class WithoutFinally 

      public void foo() throws IOException 

//在任一个空闲的端口上创建一个套接字 
ServerSocket ss = new ServerSocket(0); 
try 
        { 
       Socket socket = ss.accept(); 
       //此处的其他代码... 

catch (IOException e) 
       { 
       ss.close();                                              //1 
       throw e; 

//... 
ss.close();                                                //2 

}

这段代码创建了一个套接字,并调用 accept 方法。在退出该方法之前,您必须关闭此套接字,以避免资源漏洞。为了完成这一任务,我们在 //2 处调用 close,它是该方法的最后一条语句。但是,如果 try 块中发生一个异常会怎么样呢?在这种情况下,//2 处的 close 调用永远不会发生。因此,您必须捕获这个异常,并在重新发出这个异常之前在 //1 处插入对 close 的另一个调用。这样就可以确保在退出该方法之前关闭套接字。

这样编写代码既麻烦又易于出错,但在没有 finally 的情况下这是必不可少的。不幸的是,在没有 finally 机制的语言中,程序员就可能忘记以这种方式组织他们的代码,从而导致资源漏洞。Java 中的 finally 子句解决了这个问题。有了 finally,前面的代码就可以重写为以下的形式:

import java.net.*; 
import java.io.*;

class WithFinally 

public void foo2() throws IOException 

//在任一个空闲的端口上创建一个套接字 
ServerSocket ss = new ServerSocket(0); 
try 
        { 
      Socket socket = ss.accept(); 
      //此处的其他代码... 

finally 
        { 
       ss.close(); 


}

finally 块确保 close 方法总被执行,而不管 try 块内是否发出异常。因此,可以确保在退出该方法之前总会调用 close 方法。这样您就可以确信套接字被关闭并且您没有泄漏资源。在此方法中不需要再有一个 catch 块。在第一个示例中提供 catch 块只是为了关闭套接字,现在这是通过 finally 关闭的。如果您确实提供了一个 catch 块,则 finally 块中的代码在 catch 块完成以后执行。

finally 块必须与 try 或 try/catch 块配合使用。此外,不可能退出 try 块而不执行其 finally 块。如果 finally 块存在,则它总会执行。(无论从那点看,这个陈述都是正确的。有一种方法可以退出 try 块而不执行 finally 块。如果代码在 try 内部执行一条 System.exit(0); 语句,则应用程序终止而不会执行 finally 执行。另一方面,如果您在 try 块执行期间拨掉电源,finally 也不会执行。)

finalize 

Java技术使用finalize()方法在垃圾收集器将对象从内存中清除出去前,做必要的清理工作。这个方法是由垃圾收集器在确定这个对象没有被引用时对这个对象调用的。它是在Object类中定义的,因此所有的类都继承了它。子类覆盖finalize()方法以整理系统资源或者执行其他清理工作。finalize()方法是在垃圾收集器删除对象之前对这个对象调用的。

Java语言规范,不仅不保证终结方法会被及时的执行,而且根本不保证他们会被执行。不应该依赖终结方法来更新重要的状态。

时间: 2024-11-05 21:58:21

final finally finalize的相关文章

final、finalize、finally

final.finalize.finally final:用于声明属性,方法和类,分别表示属性不可变,方法不可覆盖,类不可继承. 说明:final 声明的成员变量,必须在声明的同时赋值.final 声明的局部变量和普通的局部变量一样,可以在声明的同时不赋初值,但是在使用前必须赋值. finalize 是Object 类的一个方法,在垃圾收集器执行的时候会调用被回收对象的此方法,可以覆盖此方法提供垃圾收集时的其他资源回收,例如关闭文件等. finally:return.continue和break

【动力节点java培训】final, finally, finalize的区别

[动力节点java培训]final, finally, finalize的区别 final 用于声明属性,方法和类,分别表示属性不可变,方法不可覆盖,类不可继承.finally是异常处理语句结构的一部分,表示总是执行.finalize是Object类的一个方法,在垃圾收集器执行的时候会调用被回收对象的此方法,可以覆盖此方法提供垃圾收集时的其他资源回收,例如关闭文件等. 如果您对动力节点有兴趣,可以登录官网看看免费教学视频:http://dwz.cn/29yALNN java学习交流QQ群:425

Android源码中final关键字的用法及final,finally,finalize的区别

Android开发的学习流程 final,finally,finalize的区别 Android的发展越来越快,Android开发人员越来越多,当两种情况碰撞,在诸多开发者中跟紧Android步伐脱颖而出就显得十分必要,虽然Android开发行业薪资高,潜力大,但人往高处走,有更大的上升空间就一定要抓住机会,Android开发行业其实很简单,高技能行业行业唯一重要的要求就是技能,所以学好Android开发直接关系到未来的职业发展,千锋Android培训机构作为行业最具权威的Android研发和人

浅析final finally finalize

1.final final修饰类,说明这个类不能被继承,是个顶级类. final修饰变量,说明这个变量是常量,初始化后不能再改. fianl修饰方法,表示这个方法不能被重写,不过可以重载final修饰的方法.(常见的final方法是object类中的wait(),notify()方法) 2.finally finally是关键字,在异常处理中,try字句中执行需要运行的内容,catch字句中用于捕获异常,finally字句表示不管是否发生异常,都会执行.finally可有可无.但是try....

final, finally, finalize的区别

finalfinal修饰类,方法,基本类型变量,引用的时候分别有不同的意思修饰类 表示该类不能被继承修饰方法 表示该方法不能被重写修饰基本类型变量 表示该变量只能被赋值一次修饰引用 表示该引用只能一次指向对象的机会finallyfinally 是用于异常处理的场面,无论是否有异常抛出,都会执行finalizefinalize是Object的方法,所有类都继承了该方法. 当一个对象满足垃圾回收的条件,并且被回收的时候,其finalize()方法就会被调用

final、finalize 和 finally 的不同之处

(1) final:修饰符(关键字),如果一个类被声明为final,意味着它不能再派生出新的子类,不能作为父类被继承.因此一个类不能既被声明为 abstract的,又被声明为final的.将变量或方法声明为final,可以保证它们在使用中不被改变.被声明为final的变量必须在声明时给定初值,而在以后的引用中只能读取,不可修改.被声明为final的方法也同样只能使用,不能重载 (2) finally:在异常处理时提供 finally 块来执行任何清除操作.如果抛出一个异常,那么相匹配的 catc

Java中的final, finally, finalize的区别

final修饰符(关键字),如果一个类被声明为final,意味着它不能再派生出新的子类,不能作为父类被继承.因此一个类不能既被声明为abstract的,又被声明为final的.将变量或方法声明为final,可以保证它们在使用中不被改变.被声明为final的变量必须在声明时给定初值,而在以后的引用中只能读取,不可修改.被声明为final的方法也同样只能使用,不能重载.方法的参数被final修饰表示在方法体内,该参数的值不可以被修改. finally在异常处理时提供finally块来执行任何清除操作

Java之final、finalize、finally的区别

一.性质不同(1)final为关键字:(2)finalize()为方法:(3)finally为为区块标志,用于try语句中:二.作用(1)final为用于标识常量的关键字,final标识的关键字存储在常量池中(在这里final常量的具体用法将在下面进行介绍):(2)finalize()方法在Object中进行了定义,用于在对象“消失”时,由JVM进行调用用于对对象进行垃圾回收,类似于C++中的析构函数:用户自定义时,用于释放对象占用的资源(比如进行I/0操作):(3)finally{}用于标识代

final, finally, finalize的区别描述

C++11标准提供了说明符final.需要注意的是,C++11中的final不是关键字,而是说明符,这意味着您可以将它(在不引起混淆的情况下)将它作为标识符使用(为了兼容以前的代码).关键字final有"这是无法改变的"或者"终态的"含义,它可以修饰非抽象类.非抽象类成员方法和变量. C++11标准提供了说明符final,用于阻止派生类覆盖特定的虚方法.或是阻止一个类成为基类. 语法1:class Someclass final {...}; 语法2:class S