String 、Integer 都是final 修飾的累,都很好的重寫了 hashCode 和 equals方法,最關(guān)鍵的他們是Immutable類,為不可變類??梢员WChashCode的穩(wěn)定性。
思考,為什么我們?cè)贖ashMap put key 的時(shí)候經(jīng)常使用String 或者Integer?
A:String 、Integer 都是final 修飾的累,都很好的重寫了 hashCode 和 equals方法,最關(guān)鍵的他們是Immutable類,為不可變類??梢员WChashCode的穩(wěn)定性。
不可變類的優(yōu)點(diǎn)與用途
1. 線程安全,省去了加鎖的過程,因?yàn)閷?duì)象內(nèi)容不可變就不用擔(dān)心線程同時(shí)對(duì)對(duì)象做修改
2. 拷貝效率高。當(dāng)類不可變時(shí), 拷貝其對(duì)象只需拷貝指針即可,而不用拷貝對(duì)象本身,不用擔(dān)心會(huì)被修改
3. 可以作為HashMap的key,類不可變保證了Hashcode的穩(wěn)定性。
如果讓你實(shí)現(xiàn)一個(gè)自定義的class作為HashMap的key該如何實(shí)現(xiàn)?
A:主要關(guān)注兩點(diǎn)即可
覆寫hashCode以及equals方法應(yīng)該遵循的原則
實(shí)現(xiàn)一個(gè)Immutable的類,那么如何實(shí)現(xiàn)一個(gè)不可變類呢。
1)類需要用final修飾
2)成員變量使用 private final 修飾、對(duì)外不提供set方法。
3)如果成員函數(shù)使用構(gòu)造函數(shù)去接受外部的數(shù)據(jù),成員變量,需要使用接受對(duì)象的拷貝(copy)
4)Get方法返回外部接受的成員變量,返回成員變量的拷貝(copy)
package com.jessyframe.learn;
import java.lang.String;
import java.utils.Arrays;
/**
*
* Created by jessy on 2022/12/24.
*/
public final class Immutable {
private final int identity;
private final String value;
private final int[] arr;
public Immutable(int identity, String value, int[] outArr) {
this.identity = identity;
this.value = value;
//this.arr = outArr; //不正確
this.arr = outArr.clone();//使用傳入數(shù)組的copy初始化
}
public int[] getArr() {
//return arr; //不正確
return arr.clone(); //返回?cái)?shù)組的copy
}
public static void main(String[] args) {
int[] arr = new int[]{12,34};
Immutable im = new Immutable(123,"jessyframe", arr);
int[] arr1 = im.getArr();
Arrays.stream(arr1).forEach((e) -> {System.out.println(e);});
arr[0] = 56;
arr[1] = 78;
Arrays.stream(arr1).forEach((e) -> {System.out.println(e);});
}
}