Final类型数据的初始化

本文深入探讨了Java中final关键字的用法,特别是针对基本类型和引用类型的初始化方式。通过实例展示了如何在构造方法中初始化final变量,确保其唯一性和不可变性。

final类型的数据(基本类型和引用类型)分为编译是确定值,和运行时确定值两类。都要保证在使用前进行初始化,注意final类型的数据若在定义时没有显示初始化,是没有默认初值的。对于在定义时没有显式初始化的,应该在构造方法中进行初始化,这时可以利用不同参数传递给它,使得它可以根据具体对象的不同而不同,并且保证在不同的对象中始终唯一。

//FinalDataInitial.java
//Fianl data in the constructor

package com.msn.spaces.bryantd001;

public class FinalDataInitial{

    //编译时初始化
    private final int finalInt=10; 
    private final float finalFloat=returnFloatValue();
    //运行时初始化
    private final double finalDouble;
    private final String finalStr;

    public FinalDataInitial(){
           System.out.println("Final data are initialized in the constructor without arguments");
           finalDouble=20;
           finalStr="I am a final string initialized in the constructor without argument";
           System.out.println(this);
    }

    public FinalDataInitial(double finalDouble, String finalStr){
          System.out.println("Final data are initialized in the constructor with arguments");
          this.finalDouble=finalDouble;
          this.finalStr=finalStr;
         System.out.println(this);
    }

    public float returnFloatValue(){
          return 1.0f;
    }

    public String toString(){
          return "finalInt = "+finalInt+"/n"
                   +"finalFloat = "+finalFloat+"/n"
                   +"finalDouble = "+finalDouble+"/n"
                   +"finalStr = "+finalStr;
    }

    public static void main(String[] args){
          FinalDataInitial fdiObj=new FinalDataInitial();
          System.out.println();
          FinalDataInitial fdiObj2=new FinalDataInitial(5.0d, new String("I am a final string initialized in the onstructor with argument"));  
    }

}

### Java中创建并初始化一个 `final` 类型的 `Map` 在Java中,可以通过多种方式来创建并初始化一个 `final` 类型的 `Map`。以下是几种常见的方法: #### 1. 使用构造器初始化 通过直接在声明时使用构造器初始化 `Map`,这种方式适用于简单的键值对初始化。 ```java private static final Map<String, Integer> MAP_EXAMPLE = new HashMap<>() {{ put("one", 1); put("two", 2); put("three", 3); }}; ``` 上述代码利用了匿名内部类的方式,在实例初始化块中调用 `put` 方法完成键值对的插入[^1]。 #### 2. 使用静态代码块初始化 当需要更复杂的逻辑或者大量的键值对时,可以结合静态代码块进行初始化。 ```java private static final Map<String, Integer> MAP_EXAMPLE = new HashMap<>(); static { MAP_EXAMPLE.put("one", 1); MAP_EXAMPLE.put("two", 2); MAP_EXAMPLE.put("three", 3); } ``` 这种方式允许在静态代码块中执行任意复杂的逻辑,适合处理动态计算的键值对[^1]。 #### 3. 使用不可变集合(推荐) 从Java 9开始,`Map` 提供了创建不可变集合的工厂方法。这种方式不仅简洁,而且生成的集合是线程安全的。 ```java private static final Map<String, Integer> MAP_EXAMPLE = Map.of( "one", 1, "two", 2, "three", 3 ); ``` 需要注意的是,`Map.of` 方法创建的集合是不可变的,尝试对其进行修改将抛出 `UnsupportedOperationException`[^2]。 #### 4. 结合流式操作初始化 如果键值对来源于其他集合或数据源,可以使用流式操作结合 `Collectors.toMap` 方法来初始化。 ```java private static final Map<String, Integer> MAP_EXAMPLE = Arrays.asList( new AbstractMap.SimpleEntry<>("one", 1), new AbstractMap.SimpleEntry<>("two", 2), new AbstractMap.SimpleEntry<>("three", 3) ).stream().collect(Collectors.toMap(Map.Entry::getKey, Map.Entry::getValue)); ``` 这种方法特别适合从已有数据结构中提取键值对。 #### 5. 在实体类中封装 `Map` 在某些场景下,可能需要将 `Map` 封装到一个实体类中,例如返回固定的字典值。 ```java @Data @AllArgsConstructor @NoArgsConstructor @Builder public class DictDTO { private String dictType; private String dictDescription; private Map<String, String> dictMaps; } private static final DictDTO DICT_DTO = DictDTO.builder() .dictType("TYPE_A") .dictDescription("This is a test type") .dictMaps(Map.of("key1", "value1", "key2", "value2")) .build(); ``` 这种方式适用于需要将 `Map` 与其他属性组合成一个完整的对象[^3]。 ---
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值