• Java final关键字


    1.概述

    final关键字代表的是最终的,不可改变

    常见四种用法

    (1)可以用来修饰一个类

    (2)可以用来修饰一个方法

    (3)可以用来修饰一个成员变量

    (4)可以用来修饰一个局部变量

    2.final关键字用来修饰类

     当final关键字用来修饰一个类的时候

    格式:

    public final class 类名称 {

      // ...

    }

    含义:当前这个类不能有任何的子类(太监类)

    注意:一个类如果是final,那么其中所有的成员方法都不能进行覆盖重写(因为没有子类)

     3.final关键字用来修饰成员方法

    当final关键字用来修饰一个方法的时候,这个方法就是最终方法,也就是不能覆盖重写。

    格式:

    修饰符 final 返回值类型 方法名称(参数列表) {

      // 方法体

    }

    注意:

    对于类、方法来说,abstract关键字和final关键字是不能同时使用,因为矛盾

    因为父类中的方法是abstract,子类中必须要重写这个方法的。而final则是不能被覆盖重写。

     4.final关键字修饰局部变量

     一旦使用final用来修饰局部变量,那么这个变量就不能进行更改。一次赋值,终生不变。

     对于基本类型来说,不可变说的是变量当中的数据不可改变

    对于引用类型来说,不可变说的是变量中的地址值不可改变

     运行结果:

    可以看到地址不一样

    但是如果用final修饰的话

     student2的地址值不可改变,但是其内容可以改变

    如:

     5.final关键字用来修饰成员变量

     对于成员变量来说,如果使用final关键字修饰,那么这个变量照样不可变。

    (1)由于成员变量具有默认值,所以用了final之后,必须手动赋值,不会再给默认值

    (2)对于final的成员变量,要么使用直接赋值,要么通过构造方法赋值,二者选其一

    (3)必须保证类当中所有重载的构造方法,都最终会对final成员变量进行赋值

    直接赋值:

     构造方法赋值:

    必须保证所有重载形式的构造方法,都最终会对final的成员变量赋值

  • 相关阅读:
    从B树、B+树、B*树谈到R 树
    1.红黑树和自平衡二叉(查找)树区别 2.红黑树与B树的区别
    红黑树 Java实现
    自平衡二叉(查找树/搜索树/排序树) binary search tree
    从零开始: 二叉查找
    深入理解JAVA虚拟机JVM
    java中的变量各占得字节数
    java中new两个对象,在堆中开辟几个对象空间
    Spring面试,IoC和AOP的理解, @Transactional原理及使用
    EasyUI Tabs + Yii2.0实现iframe方式打开页面(解决共用静态文件引入加载的问题)
  • 原文地址:https://www.cnblogs.com/GumpYan/p/13807168.html
Copyright © 2020-2023  润新知