除了变量,final还能修饰哪些Java元素

本文涉及的产品
云原生数据库 PolarDB 分布式版,标准版 2核8GB
云原生数据库 PolarDB PostgreSQL 版,标准版 2核4GB 50GB
云原生数据库 PolarDB MySQL 版,通用型 2核4GB 50GB
简介: 在Java中,final关键字不仅可以修饰变量,还可以用于修饰类、方法和参数。修饰类时,该类不能被继承;修饰方法时,方法不能被重写;修饰参数时,参数在方法体内不能被修改。
  1. 修饰方法
    • 功能和目的:当一个方法被final修饰时,它不能在子类中被重写。这确保了该方法的实现在继承层次结构中保持不变,对于一些核心的业务逻辑方法或者不希望被子类改变行为的方法非常有用。例如,在一个数学计算工具类中,有一个计算圆面积的方法calculateCircleArea,为了保证计算方法的准确性和一致性,不希望子类去改变这个方法的实现,就可以将其声明为final
    • 示例代码
      class MathUtils {
             
      public final double calculateCircleArea(double radius) {
             
         return Math.PI * radius * radius;
      }
      }
      class SubMathUtils extends MathUtils {
             
      // 以下代码会导致编译错误,因为不能重写final方法
      // public double calculateCircleArea(double radius) {
             
      //     return 0; 
      // }
      }
      
  2. 修饰类
    • 功能和目的final修饰类表示该类不能被继承。这在设计一些具有固定功能和结构的类时很有用,比如一些提供底层系统服务的类或者只是作为数据载体的类(如Java中的String类),不希望其他类去扩展它们,以避免对其内部逻辑的干扰。另外,对于一些安全相关的类,通过将其声明为final可以防止恶意继承和篡改。
    • 示例代码
      // 定义一个final类
      final class ImmutablePoint {
             
      private final int x;
      private final int y;
      public ImmutablePoint(int x, int y) {
             
         this.x = x;
         this.y = y;
      }
      public int getX() {
             
         return x;
      }
      public int getY() {
             
         return y;
      }
      }
      // 以下代码会导致编译错误,因为不能继承final类
      // class SubImmutablePoint extends ImmutablePoint {
             
      // }
      
  3. 修饰引用(包括数组引用)
    • 功能和目的:当final修饰引用时,引用本身不能被重新赋值,但引用所指向的对象的内容(如果是可变对象)可以被修改。这在处理一些需要固定引用但允许对象内部状态变化的情况时很有用。例如,在一个缓存系统中,缓存的键值对存储结构的引用可能需要保持不变,但其中存储的值对象(如果是可变的)可以根据业务逻辑进行更新。
    • 示例代码 - 基本类型数组引用
      final int[] finalArray = {
             1, 2, 3};
      // 以下代码会导致编译错误,因为不能重新赋值final引用
      // finalArray = new int[]{4, 5, 6};
      // 但是可以修改数组元素的值
      finalArray[0] = 4;
      
    • 示例代码 - 对象数组引用
      class Person {
             
      private String name;
      public Person(String name) {
             
         this.name = name;
      }
      public String getName() {
             
         return name;
      }
      public void setName(String name) {
             
         this.name = name;
      }
      }
      final Person[] finalPersonArray = new Person[2];
      finalPersonArray[0] = new Person("Alice");
      // 以下代码会导致编译错误,因为不能重新赋值final引用
      // finalPersonArray = new Person[3];
      // 但是可以修改数组元素(对象)的内部状态
      finalPersonArray[0].setName("Bob");
      
相关文章
|
2月前
|
存储 Java
深入探讨了Java集合框架中的HashSet和TreeSet,解析了两者在元素存储上的无序与有序特性。
【10月更文挑战第16天】本文深入探讨了Java集合框架中的HashSet和TreeSet,解析了两者在元素存储上的无序与有序特性。HashSet基于哈希表实现,添加元素时根据哈希值分布,遍历时顺序不可预测;而TreeSet利用红黑树结构,按自然顺序或自定义顺序存储元素,确保遍历时有序输出。文章还提供了示例代码,帮助读者更好地理解这两种集合类型的使用场景和内部机制。
41 3
|
2月前
|
Java
在Java的世界里,Set只接纳独一无二的元素。
【10月更文挑战第16天】在Java的世界里,Set只接纳独一无二的元素。本文通过拟人化的手法,讲述了重复元素从初次尝试加入Set被拒绝,到经历挣扎、反思,最终通过改变自己,成为独特个体并被Set接纳的全过程。示例代码展示了这一过程的技术实现。
25 1
|
4月前
|
存储 算法 Java
Arraylist 在 Java 中能容纳多少个元素?
【8月更文挑战第23天】
121 0
|
4月前
|
存储 Java
|
4月前
|
缓存 Java
Java本地高性能缓存实践问题之AsyncCache中移除一个缓存元素的问题如何解决
Java本地高性能缓存实践问题之AsyncCache中移除一个缓存元素的问题如何解决
|
17天前
|
Java
那些与Java Set擦肩而过的重复元素,都经历了什么?
在Java的世界里,Set如同一位浪漫而坚定的恋人,只对独一无二的元素情有独钟。重复元素虽屡遭拒绝,但通过反思和成长,最终变得独特,赢得了Set的认可。示例代码展示了这一过程,揭示了成长与独特性的浪漫故事。
20 4
|
24天前
|
存储 Java
判断一个元素是否在 Java 中的 Set 集合中
【10月更文挑战第30天】使用`contains()`方法可以方便快捷地判断一个元素是否在Java中的`Set`集合中,但对于自定义对象,需要注意重写`equals()`方法以确保正确的判断结果,同时根据具体的性能需求选择合适的`Set`实现类。
|
22天前
|
存储 算法 Java
为什么Java Set如此“挑剔”,连重复元素都容不下?
在Java的集合框架中,Set是一个独特的接口,它严格要求元素不重复,适用于需要唯一性约束的场景。Set通过内部数据结构(如哈希表或红黑树)和算法(如哈希值和equals()方法)实现这一特性,自动过滤重复元素,简化处理逻辑。示例代码展示了Set如何自动忽略重复元素。
26 1
|
2月前
|
存储 Java 数据处理
Set 是 Java 集合框架中的一个接口,不包含重复元素且不保证元素顺序。
【10月更文挑战第16天】Java Set:无序之美,不重复之魅!Set 是 Java 集合框架中的一个接口,不包含重复元素且不保证元素顺序。通过 hashCode() 和 equals() 方法实现唯一性,适用于需要唯一性约束的数据处理。示例代码展示了如何使用 HashSet 添加和遍历元素,体现了 Set 的高效性和简洁性。
36 4
|
2月前
|
存储 Java 数据处理
Set 是 Java 集合框架中的一个接口,不包含重复元素且不保证元素顺序。
Java Set:无序之美,不重复之魅!Set 是 Java 集合框架中的一个接口,不包含重复元素且不保证元素顺序。它通过 hashCode() 和 equals() 方法确保元素唯一性,适用于需要唯一性约束的数据处理。示例代码展示了如何使用 HashSet 实现这一特性。
31 5