final的作用随着所修饰的类型而不同

1、final修饰类中的属性或者变量

不管属性是基本类型还是引用类型。final所起的作用都是变量里面存放的“值”不能变。

这个值,对于基本类型来说,变量里面放的就是实实在在的值,如1,“abc”等。

   
而引用类型变量里面放的是个地址。所以用final修饰引用类型变量指的是它里面的地址不能变。并非说这个地址所指向的对象或数组的内容不能够变,这个一定要注意。

比如:类中有一个属性是final Person p=new Person("name");
那么你不能对p进行又一次赋值,可是能够改变p里面属性的值,p.setName('newName');

p是引用变量  它里面存的一个地址,不能改变  可是我们能够改变这个地址指向的对象的属性值。

watermark/2/text/aHR0cDovL2Jsb2cuY3Nkbi5uZXQvdTAxMDYzNDA2Ng==/font/5a6L5L2T/fontsize/400/fill/I0JBQkFCMA==/dissolve/70/gravity/SouthEast" alt="">

final修饰属性,声明变量时能够不赋值。并且一旦赋值就不能被改动了。

对final属性能够在三个地方赋值:声明时、初始化块中、构造方法中。总之中的一个定要赋值。

2、final修饰类中的方法

作用:能够被继承。但继承后不能被重写。

3、final修饰类

作用:类不能够被继承。

思考一个有趣的现象:

byte b1=1;

byte b2=3;

byte b3=b1+b2;//当程序运行到这一行的时候会出错,由于b1、b2能够自己主动转换成int类型的变量。运算时java虚拟机对它进行了转换,结果导致把一个int赋值给byte-----出错

假设对b1 b2加上final就不会出错

final byte b1=1;

final byte b2=3;

byte b3=b1+b2;//不会出错,相信你看了上面的解释就知道原因了。

以上内容是转载于http://blog.csdn.net/linchunhua/article/details/5305452

下面为自己见解

我们知道一个定义为final的对象引用仅仅能指向唯一一个对象(由于地址不能更改)可是一个对象的本身的值是能够改变的;

比方:

Random rand=new Random();

public final int A_1=rand.nextInt(10);

这里A_1每次执行的结果都不同的。

为了将一个常量真正做到不可更改 能够将常量声明为static final。

public static final int A_2=rand.nextInt(10);

这里结果每次执行都是同样的。

static final形式。它在内存中为A_2开辟了一个恒定不变的区域,当再次实例化对象的时候,任然指向A_2这块内存区域。所以A_2保持不变。A_2是在

装载的时候被初始化,而不是每次创建新的对象时都被初始化

final方法

final定义方法不能被覆盖

注意:一个父类的某个方法定义了private修饰符  。子类将无法訪问  自然就无法覆盖

//final 类
public class finalParent {
private final void doit(){
System.out.println("父类.doit()");
}
final void doit2(){
System.out.println("父类.doit2()");
}
public void doit3(){
System.out.println("父类.doit3()");
}
}

public class finalFindMethod {
public static void main(String[] args){
Sub s=new Sub();
s.doit();//结果是子类.doit()
finalParent p=s;//向上转型
p.doit2();
p.doit3();
}
}
//在父类定义了doit(),子类也定义了doit()看似是子类覆盖了父类的方法。可是覆盖必须能够满足一个对象向上转型为他的基本类型
//而且调用同样方法的这一条件;父类中带了private是主类的私有方法,子类仅仅是新定义了一个方法而已,二不是覆盖
//final的方法不能被子类继承

public class Sub extends finalParent {
final void doit() {
System.out.println("子类.doit()");
} // final void doit2(){ //这里显示不能重写父类为final的方法
//
// }
public void doit3() {
System.out.println("子类.doit3()");
}
}
结果:
子类.doit()

父类.doit2()

子类.doit3()
//在父类定义了doit(),子类也定义了doit()看似是子类覆盖了父类的方法,可是覆盖必须能够满足一个对象向上转型为他的基本类型

//而且调用同样方法的这一条件;父类中带了private是主类的私有方法,子类仅仅是新定义了一个方法而已,二不是覆盖

//final的方法不能被子类继承





final使用方法的更多相关文章

  1. 利用final定义方法:这样的方法为一个不可覆盖的方法。

      常量(这里的常量指的是实例常量:即成员变量)赋值: ①在初始化的时候通过显式声明赋值.Final int x=3: ②在构造的时候赋值. 局部变量可以随时赋值.   利用final定义方法:这样的 ...

  2. java中static,final,private方法的继承多态问题

    父类中的final  private方法不能被继承,父类中的static方法可以被继承,但是不能重写,这三者都属于前期绑定,java中除了这三种以及构造方法之外剩下的都是后期绑定(运行是绑定). 当父 ...

  3. static和final修饰方法

    static修饰的方法是静态方法,所有的对象共用一份,也就是共享方法.static方法是可以被继承,然后可以被重写和重载. final修饰的方法是不可变方法,final方法所在类被继承时,被final ...

  4. Java final 关键词修饰类、方法、变量

    1. final修饰类  被修饰的类不能被继承,也没有子类.假如随意创建这些类的子类,子类可能会错误的修改父类的实现细节.出于安全原因,类的实现细节不允许有任何改动.在创建对象模型的时候,确信这个类不 ...

  5. final 关键字:用来修饰类,方法,成员变量,局部变量

    final 关键字:用来修饰类,方法,成员变量,局部变量 表示最终的不可变的 1.final修饰一个类 表示当前的类不能有子类,也就是不能将一个类作为父类 格式: public final class ...

  6. Java中final关键字修饰变量、方法、类的含义是什么

    Java中的关键字final修饰变量.方法.类分别表示什么含义? 先看一个简单的介绍 修饰对象 解释说明 备注 类 无子类,不可以被继承,更不可能被重写. final类中的方法默认是final的 方法 ...

  7. Final类和Final方法

    终止继承 Final类 当关键字final用来修饰类时,其含义是该类不能在派生子类.换句话说,任何其他类都不能继承用final修饰的类,即使该类的访问限制为public类型,也不能被继承:否则,将编译 ...

  8. java中final关键字的使用方法

     [java中为什么会有final变量]: final这个关键字的含义是"这是无法改变的"或者"终态的": 那么为什么要阻止改变呢? java语言的发明者可 ...

  9. java类中final方法的作用

    不给子类复写这个方法.说明你已经知道这个方法提供的功能已经满足你要求,不需要进行扩展,并且也不允许任何从此类继承的类来覆写这个方法,但是继承仍然可以继承这个方法,也就是说可以直接使用 inline扩展 ...

随机推荐

  1. js中编码的处理

    今天修bug的时候对编码问题进行了解决.发现js中有一个escape()这个函数处理编码的问题. 定义跟方法: 语法 escape(string)String:必需,要被转义或者编码的字符串. 返回值 ...

  2. 44.AngularJS Bootstrap

    转自:https://www.cnblogs.com/best/tag/Angular/ Bootstrap 你可以在你的 AngularJS 应用中加入 Twitter Bootstrap,你可以在 ...

  3. hive parquet table 配置使用压缩

    创建parquet table : create table mytable(a int,b int) STORED AS PARQUET; 创建带压缩的parquet table: create t ...

  4. nil / Nil / NULL / NSNull VS objc_msgSend

    [NSNull null]是一个对象,其类为NSNULL(isa):里面没有任何变量.函数.和实现. nil的处理展示出消息机制的优越性,相对于函数调用的空指针处理. ENTRY objc_msgSe ...

  5. Linux 运维笔试题(一)

    试题:   1.说出下列服务对应的端口或者端口对应的服务 21  23  25  873  161  111  110  53  123  2049   2.文件atime,ctime,mtime的区 ...

  6. UNIX 是什么?怎么诞生的?

    要记住, 当一扇门在你面前关闭的时候, 另一扇门就会打开. 肯·汤普森(Ken Thompson) 和丹尼斯·里奇(Dennis Richie)两个人就是这句名言很好的实例.他们俩是20世纪最优秀的信 ...

  7. caffe for python (官方翻译)

    导言 本教程中,我们将会利用Caffe官方提供的深度模型——CaffeNet(该模型是基于Krizhevsky等人的模型的)来演示图像识别与分类.我们将分别用CPU和GPU来进行演示,并对比其性能.然 ...

  8. [转载][来自csdn]RTS和CTS是什么意思?

    原文链接: http://blog.csdn.net/zmq5411/article/details/6280332 这篇文章看着挺好,明白易懂,顺手转过来 34RTS和CTS是什么意思? 解释一:R ...

  9. Linux中常用命令(文件)

    1.cat 显示出文件的全部内容 (1)格式:cat 文件名 -n 显示行号 (2)特点:一次性显示所有文件内容 2.tac 从最后一行倒着显示文件全部内容 3.more 全屏方式分页显示文件内容 回 ...

  10. lsof---查看你进程开打的文件

    lsof命令用于查看你进程开打的文件,打开文件的进程,进程打开的端口(TCP.UDP).找回/恢复删除的文件.是十分方便的系统监视工具,因为lsof命令需要访问核心内存和各种文件,所以需要root用户 ...