Thinking In Java final关键字

可能使用到final的三种情况:数据、方法和类

1.final数据

有时候数据的恒定不变是很有用的,比如:
1.一个永不改变的编译时常量
2.一个在运行时被初始化的值,而不希望它被改变

一个既是static又是final的域只占据一段不能改变的存储空间。根据惯例,既是static又是final的域(即编译时常量)用大写表示,并使用下划线分割各个单词。

我们不能因为数据是final的就认为在编译时可以知道它的值。以下这段代码展示了这一点:

Random random = new Random(47);
final int value = random.nextInt();

当final修饰对象的时候,代表不能将这个引用指向另一个新的对象,但是对象本身是可以改变的。这对数组具有同样的意义,数组只不过是另一种引用。

空白final

Java允许生成“空白final”,所谓空白final是指被声明为final但又未给定初值的域。无论什么情况,编译器都确保空白final在使用前被初始化。因此必须在域的定义处或者每个构造器中用表达式对final进行赋值,这就是final域在使用前总被初始化的原因所在。

final参数

Java允许在参数列表中以声明的方式将参数指明为final。这意味着在方法中无法更改参数引用所指向的对象。你可以读参数,但是无法修改参数。这一特性主要用来向匿名内部类传递数据。

2.final方法

使用final方法的原因:把方法锁住,防止任何继承类修改它的含义,这是出于设计的考虑:要确保在继承中使方法行为保持不变,并且不会被覆盖。

final和private关键字

类中所有的private方法都隐式地指定为final的。由于无法取用private方法,也就无法覆盖它。
但是当你继承某一个父类的private方法时发现似乎是奏效的:
class Father() {
private final void f() {}
}
class Child(){
private final void f() {System.out.print(“hello!”)}
}
但是实际上,“覆盖”只有在某方法是基类的接口的一部分时才会出现。即必须能将一个对象向上转型为它的基本类型并调用相同的方法。如果某方法是private,它就不是基类的接口的一部分。它仅是一些隐藏与类中的程序代码,只不过具有相同的名称而已。由于private方法无法触及而且能有效的隐藏,所以除了把它看成是因为它所属的类的组织结构的原因而存在外,其他任何事务都不需要考虑它

3.final类

当将某个类的整体定义为final时,就表明了你不打算继承该类,而且也不允许别人这样做。换句话说出于某种考虑,你对该类的设计不需要做任何变动,或者出于安全的考虑,你不希望它拥有子类。
类似下面这样:
final class CannotExtends {}
final类的域可以根据个人的意愿选择为是或不是final。不论类是否被定义为final,相同的规则都适用于定义为final的域。由于final类禁止继承,所以final类中所有的方法都隐式指定为final,因为无法覆盖它们。在final类中可以给方法添加final修饰词,但这不会增添任何意义。

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值