值對的綜合集合:Java 的Map.Entry 和SimpleEntry 簡介
在Java 中,定義集合時,每個元素包含定義集合時,每個元素包含定義一個由於具有不同類型的值對,通常使用Map。然而,對於維護元素順序至關重要且不關心唯一性的場景,有一個有價值的替代方案:Java 的Map.Entry 介面及其實作SimpleEntry.
Map.Entry 和SimpleEntry :完美對
Map.Entry 提供了一個框架,用於表示Map 中的單一鍵值關聯。它擁有兩個泛型型別參數,
建立和利用值對
建立鍵值對值,實例化一個 SimpleEntry 對象,指定鍵和值的類型。例如:
Map.Entry<String, Integer> pair1 = new SimpleEntry<>("Key 1", 10);
或者,您可以利用Java 的varargs(可變長度參數)功能在一行中建立多個對:
var pairList = List.of( new SimpleEntry<>("Key 1", 10), new SimpleEntry<>("Key 2", 20) );
利用泛型和子類化
為了進一步增強可讀性和可維護性,您可以擁抱泛型和子類化。建立一個擴展 ArrayList
class TupleList<T extends Map.Entry<K, V>> extends ArrayList<T> { public TupleList<T> of(K key, V value) { add(new SimpleEntry<>(key, value)); return this; } }
透過這個優雅的擴展,您可以使用直覺的語法快速構造值對:
TupleList<Map.Entry<String, Integer>> pair = new TupleList<>(); pair.of("Key 1", 10); pair.of("Key 2", 20);
結論
Java 的Map.Entry 和SimpleEntry 提供了一個用於儲存和操作值的通用機制對。它們的靈活性和易用性使它們成為順序和不同類型發揮重要作用的場景的絕佳選擇。透過利用泛型和子類化技術,您可以進一步簡化程式碼並實現一定程度的程式碼清晰度,從而掩蓋其潛在的複雜性。
以上是Java的Map.Entry和SimpleEntry如何簡化值對管理?的詳細內容。更多資訊請關注PHP中文網其他相關文章!