今天刚刚看到的,希望理解是正确的。大家以辩证的眼光来看待这边博客,不对的地方还望指正。
一般而言,final就是声明“这个东西不能改变”。
1.final变量
被定义为final的变量就会变为一个常数。
-----引用------
对于编译期的常数,编译器(程序)可将常数值“封装”到需要的计算过程里。也就是说,计算可在编译期
间提前执行,从而节省运行时的一些开销。
-----引用结束----
效率方面主观上我是没有什么体会的,但是使用上的变化还是比较容易感受的到。
对于final定义的变量,只能存储一个数值,不能更改。
如final int i = 0;
i在整个的使用过程中,值不能被更改,即i = 2;这样的赋值是错误的。
java里没有宏定义,要想定义一个全局的不可更改的静态的常量那就是final和static的结合,而且根据规则,变量名必须为大写:
例如:public static final int KEY_ENTER = 22;
它就相当于C里面的宏定义:#define KEY_ENTER 22
需要说明的是,final 定义的句柄不能更改,但是句柄指向的内容是可以改变的。就好比是C++里的const 指针,指向的地址不能变,但是地址里具体放什么数值,好吧,你可以换的。
如果一个函数传入的句柄参数被设置为final(private int aaaa(final View bbb).....)说明传入的参数不希望在函数体内使用时,句柄不想被更改。
2.final方法
---------引用------------
之所以要使用final 方法,可能是出于对两方面理由的考虑。第一个是为方法“上锁”,防止任何继承类改
变它的本来含义。设计程序时,若希望一个方法的行为在继承期间保持不变,而且不可被覆盖或改写,就可
以采取这种做法。
采用final 方法的第二个理由是程序执行的效率。将一个方法设成final 后,编译器就可以把对那个方法的
所有调用都置入“嵌入”调用里。只要编译器发现一个final 方法调用,就会(根据它自己的判断)忽略为
执行方法调用机制而采取的常规代码插入方法(将自变量压入堆栈;跳至方法代码并执行它;跳回来;清除
堆栈自变量;最后对返回值进行处理)。相反,它会用方法主体内实际代码的一个副本来替换方法调用。这
样做可避免方法调用时的系统开销。当然,若方法体积太大,那么程序也会变得雍肿,可能受到到不到嵌入
代码所带来的任何性能提升。因为任何提升都被花在方法内部的时间抵消了。Java 编译器能自动侦测这些情
况,并颇为“明智”地决定是否嵌入一个final 方法。然而,最好还是不要完全相信编译器能正确地作出所
有判断。通常,只有在方法的代码量非常少,或者想明确禁止方法被覆盖的时候,才应考虑将一个方法设为
final。
---------引用结束----------
写太好了,我都不知道怎么总结了。你自己看吧。
3.final类
如果一个类被定义为final.....说明人家不想被你继承啊亲~不过可以正常创建对象去使用哦。
我发现我说的好简单啊,实际上,我觉得看起来的时候很复杂的呀。我纠结了,是不是我没理解呀,肿么办,要不,我继续看,你看完博客再去看看书,巩固下~~