final关键字

来源:互联网 发布:成都拉勾网络 编辑:程序博客网 时间:2024/05/07 12:54

final代表最终的,不可改变的。其可以修饰类,方法,变量(变量的范围要比属性的范围的大)。

       1  final戏称断子绝孙类,也就是子类无法继承。final的方法不能够被重写,final的变量只能赋值一次(这里有一点需要强调的是,fanal修饰的是变量而非常量),即在初始化的时候,而且还必须赋值。

        2final修饰的类中没有set属性,由于final修饰的属性只能够赋值一次,所以不可能有set方法。如果有的话,试想当你new出一个该类的对象的时候,这个对象是能够调用set方法无数多次的,显然与final修饰的属性赋值一次相矛盾。因此,final的属性是没有set方法的。

final修饰的属性为什么不是通常意义下的常量呢?也许你会有这样的疑问,既然final修饰的属性只能赋值一次,有不能把其值给改变,为什么还不能把他当作常量?又这样的疑问是正确的。但是你可以转换一个角度想一下。针对一个对象来说,其值的确无法改变,但是当你重新new一个对象的时候,final修饰的变量一定还是可以在赋值的啊!这也就是说final在一个类中只能赋值一次,当你创建对象的时候,需要调用这个类的构造,而final修饰的变量是可以放在构造当中的,创建出来的对象,调用final修饰的属性的时候,这个属性的值不能总是相同。在这样情况下,的确是不能够把final修饰的东西当作常量来看的。试想一下如果一个常量 2,不过其对任何一个对象来说,其值永远是2,绝对是不会改变的,这样的才算是常量。

      3你也许看到过Java中在定义常量的时候,有final的影子,的确没错。你想一想,定义的常量一定是这样出现的啊:public static final   A_B = 4;这里需要解释一下的是,是否会问为什么要用public修饰而不用private或者protected来修饰呢?因为是常量,没必要隐藏,索性公开算了,这才符合常量的真正的意义。
public class Custom {private final int id;private static int i;public Custom() {id = ++i;}public int getId(){return id;}}public class Test {public static void main(String[] args){for(int i=0;i<10;i++){Custom s = new Custom();System.out.println(s.getId());}}}

这段代码编译和运行都能过去。我们分析一下,id是用final来修饰的,而i是用static来修饰的,我们看到了,id的确只能在创建对象的时候赋值一次,这没错,这就告诉我们id的值只有在创建对象的时候才能改变,也就印证了上面的说法,final修饰的属性不是常量。而static修饰的属性i,识别new出来对象所共享的,放在静态池中。放在静态池中的变量,我以前也提到过其特点:常驻内存,反复利用。这两个关键在上面的代码中同时出现,分别用来修饰两个变量,只是为了更好地证明final修饰的属性id只能赋值一次,而且是可以改变的。

补充一点:在引用类型当中final只能限定一层。

原创粉丝点击