国产av日韩一区二区三区精品,成人性爱视频在线观看,国产,欧美,日韩,一区,www.成色av久久成人,2222eeee成人天堂

首頁(yè) Java Java入門(mén) java什麼是映射

java什麼是映射

Nov 12, 2019 pm 04:57 PM
java 對(duì)應(yīng)

java什麼是映射

集合是一個(gè)集合,它可以快速地找到現(xiàn)有的元素。但是,要查看一個(gè)元素,需要有要尋找元素的精確副本。這不是一種非常通用的尋找方式,因?yàn)樵诩现袑ふ以乜偸且闅v集合。通常,我們知道某些鍵的訊息,並想要尋找與之對(duì)應(yīng)的元素。映射(map)資料結(jié)構(gòu)就是為此而設(shè)計(jì)的。映射用來(lái)存放鍵/值對(duì)。如果提供了鍵,就能夠查找到值。它們之間是一一對(duì)應(yīng)關(guān)係。

基本映射操作:

Java類(lèi)別庫(kù)為映射提供了兩個(gè)通用的實(shí)作:HashMap和TreeMap,這兩個(gè)類(lèi)別都實(shí)作了Map介面

散列映射(HashMap)對(duì)鍵進(jìn)行散列,樹(shù)映射(TreeMap)以鍵的整體順序?qū)υ剡M(jìn)行排序,並將其組織成搜尋樹(shù)。

雜湊或比較函數(shù)只能作用於鍵。與鍵關(guān)聯(lián)的值不不能進(jìn)行散列或比較

與集一樣,散列映射比樹(shù)映射稍微快一些,所以在不需要按照排列順序訪問(wèn)鍵的時(shí)候,最好選用散列映射

OP->>要進(jìn)行鍵值存儲(chǔ),必須使用put方法

OP->>要進(jìn)行鍵值訪問(wèn),必須使用get方法,且只能透過(guò)鍵來(lái)存取到值

OP->>如果找不到值卻不想傳回一個(gè)空對(duì)象,則使用getOrDefault(var1,var2),如果找不到值則回傳var2。

鍵必須是唯一的,如果對(duì)一對(duì)映射呼叫兩次put方法,則後一次呼叫會(huì)覆寫(xiě)前一次呼叫。並且傳回第一次呼叫的結(jié)果

OP->>要進(jìn)行鍵值對(duì)的移除,則要使用remove(鍵)的方法

OP->>要取得鍵值對(duì)的數(shù)量,則要使用size()方法

OP->>要迭代處理每個(gè)鍵和值,最好是使用forEach方法,可以向這個(gè)方法提供一個(gè)lambda表達(dá)式,用來(lái)依序處理映射中的每一個(gè)元素

類(lèi)似於scores.forEach((k,v)->System.out.println("key=" k ",value=" v));

下面範(fàn)例程式示範(fàn)了映射的操作過(guò)程,首先將鍵/值對(duì)新增至映射中。然後從映射中刪除一個(gè)鍵,同時(shí)與之對(duì)應(yīng)的值也被刪除了。接下來(lái),修改與某一個(gè)鍵對(duì)應(yīng)的值,並呼叫g(shù)et方法查看這個(gè)值。最後,迭代處理?xiàng)l目集。

程式碼:

package Collection.Map;
 
import java.util.*;
 
public class MapTest {
public static void main(String[] args) {
Map<String,Employee> staff=new HashMap<>();
staff.put("144-25-5464", new Employee("Amy Lee"));
staff.put("567-24-2546", new Employee("Harry Hacker"));
staff.put("157-62-7935", new Employee("Gary Cooper"));
staff.put("456-62-5527", new Employee("Francesca Cruz"));
//打印所有成員
System.out.println(staff);
//刪除某一成員
staff.remove("567-24-2546");
//替代一個(gè)成員
staff.put("456-62-5527", new Employee("Francesca Miller"));
//查看一個(gè)成員
System.out.println(staff.get("157-62-7935"));
//遍歷映射
staff.forEach((k,v)->System.out.println("key="+k+",value="+v));
}
}
 
class Employee{
String name;
 
public Employee(String name) {
this.name = name;
}
 
public String toString() {
return "[name="+name+"]";
}
}

執(zhí)行結(jié)果:

java什麼是映射

#以下是介面Map中常用的幾個(gè)方法及其解釋?zhuān)?

V get(Object key)

取得與鍵對(duì)應(yīng)的值;傳回與鍵對(duì)應(yīng)的對(duì)象,如果在映射中沒(méi)有這個(gè)物件則傳回null。鍵可以為null。

default V getOrDefault(Object key,V defaultValue)

取得與鍵關(guān)聯(lián)的值;傳回與鍵關(guān)聯(lián)的對(duì)象,或如果未在映射中找到這個(gè)鍵,則傳回defaultValue。

V put(K key,V value)

#將鍵與對(duì)應(yīng)的值關(guān)係插入到映射中。如果這個(gè)鍵已經(jīng)存在,新的物件將取代與這個(gè)鍵對(duì)應(yīng)的舊物件。這個(gè)方法將傳回鍵對(duì)應(yīng)的舊值。如果這個(gè)鍵以前沒(méi)有出現(xiàn)過(guò)則回傳null。鍵可以為null,但值不能為null。

void putAll(Map extends K,? extends V> entries)

將給定映射中所有項(xiàng)目加入到這個(gè)映射中。

boolean containsKey(Object key)

如果對(duì)應(yīng)中已經(jīng)有這個(gè)鍵,則傳回true。

boolean containsValue(Object value)

如果映射中已經(jīng)有這個(gè)值,則回傳true。

default void forEach(BiConsumer super K,? super V> action)

對(duì)這個(gè)映射中的所有鍵/值套用這個(gè)動(dòng)作。

以下是HashMap類(lèi)別中的常用方法:

HashMap()

HashMap(int initialCapacity)

#HashMap(int initialCapacity,float loadFactor)

用給定的容量和裝填因子構(gòu)造一個(gè)空散列映射(裝填因子是一個(gè)0.0~1.0之間的一個(gè)數(shù)值。這個(gè)數(shù)值決定散列表填充百分比。一旦到了這個(gè)比例,就要將其再散列到更大的表中)。預(yù)設(shè)的裝填因子是0.75。

以下是TreeMap類(lèi)別中常用的方法:

#TreeMap()

為實(shí)作Comparable介面的鍵建構(gòu)一個(gè)空的樹(shù)映射。

TreeMap(Comparator super K> c)

建構(gòu)一個(gè)樹(shù)狀映射,並使用指定的比較器對(duì)鍵進(jìn)行排序。

TreeMap(Map extends K,? extends V> entries)

建構(gòu)一個(gè)樹(shù)映射,並將某個(gè)映射中的所有條目加入樹(shù)映射中。

TreeMap(SortedMap extends K,? extends V> entries)

建構(gòu)一個(gè)樹(shù)映射,將某個(gè)有序映射中的所有條目添加到樹(shù)映射中,並使用與給定的有序映射相同的比較器。

以下是SortedMap介面的一些重要的方法:

#Comparator super K> comparator()

#返回鍵進(jìn)行排序的比較器。如果鍵是用Comparable介面的comparaTo方法進(jìn)行比較的,則回傳null。

K firstKey()

K lastKey()

傳回映射中最小元素和最大元素。

php中文網(wǎng),大量的免費(fèi)Java入門(mén)教學(xué),歡迎線上學(xué)習(xí)!

以上是java什麼是映射的詳細(xì)內(nèi)容。更多資訊請(qǐng)關(guān)注PHP中文網(wǎng)其他相關(guān)文章!

本網(wǎng)站聲明
本文內(nèi)容由網(wǎng)友自願(yuàn)投稿,版權(quán)歸原作者所有。本站不承擔(dān)相應(yīng)的法律責(zé)任。如發(fā)現(xiàn)涉嫌抄襲或侵權(quán)的內(nèi)容,請(qǐng)聯(lián)絡(luò)admin@php.cn

熱AI工具

Undress AI Tool

Undress AI Tool

免費(fèi)脫衣圖片

Undresser.AI Undress

Undresser.AI Undress

人工智慧驅(qū)動(dòng)的應(yīng)用程序,用於創(chuàng)建逼真的裸體照片

AI Clothes Remover

AI Clothes Remover

用於從照片中去除衣服的線上人工智慧工具。

Clothoff.io

Clothoff.io

AI脫衣器

Video Face Swap

Video Face Swap

使用我們完全免費(fèi)的人工智慧換臉工具,輕鬆在任何影片中換臉!

熱工具

記事本++7.3.1

記事本++7.3.1

好用且免費(fèi)的程式碼編輯器

SublimeText3漢化版

SublimeText3漢化版

中文版,非常好用

禪工作室 13.0.1

禪工作室 13.0.1

強(qiáng)大的PHP整合開(kāi)發(fā)環(huán)境

Dreamweaver CS6

Dreamweaver CS6

視覺(jué)化網(wǎng)頁(yè)開(kāi)發(fā)工具

SublimeText3 Mac版

SublimeText3 Mac版

神級(jí)程式碼編輯軟體(SublimeText3)

熱門(mén)話題

如何在Java的地圖上迭代? 如何在Java的地圖上迭代? Jul 13, 2025 am 02:54 AM

遍歷Java中的Map有三種常用方法:1.使用entrySet同時(shí)獲取鍵和值,適用於大多數(shù)場(chǎng)景;2.使用keySet或values分別遍歷鍵或值;3.使用Java8的forEach簡(jiǎn)化代碼結(jié)構(gòu)。 entrySet返回包含所有鍵值對(duì)的Set集合,每次循環(huán)獲取Map.Entry對(duì)象,適合頻繁訪問(wèn)鍵和值的情況;若只需鍵或值,可分別調(diào)用keySet()或values(),也可在遍歷鍵時(shí)通過(guò)map.get(key)獲取值;Java8中可通過(guò)Lambda表達(dá)式使用forEach((key,value)-&gt

Java中的可比較與比較器 Java中的可比較與比較器 Jul 13, 2025 am 02:31 AM

在Java中,Comparable用於類(lèi)內(nèi)部定義默認(rèn)排序規(guī)則,Comparator用於外部靈活定義多種排序邏輯。 1.Comparable是類(lèi)自身實(shí)現(xiàn)的接口,通過(guò)重寫(xiě)compareTo()方法定義自然順序,適用於類(lèi)有固定、最常用的排序方式,如String或Integer。 2.Comparator是外部定義的函數(shù)式接口,通過(guò)compare()方法實(shí)現(xiàn),適合同一類(lèi)需要多種排序方式、無(wú)法修改類(lèi)源碼或排序邏輯經(jīng)常變化的情況。兩者區(qū)別在於Comparable只能定義一種排序邏輯且需修改類(lèi)本身,而Compar

如何處理Java中的字符編碼問(wèn)題? 如何處理Java中的字符編碼問(wèn)題? Jul 13, 2025 am 02:46 AM

處理Java中的字符編碼問(wèn)題,關(guān)鍵是在每一步都明確指定使用的編碼。 1.讀寫(xiě)文本時(shí)始終指定編碼,使用InputStreamReader和OutputStreamWriter並傳入明確的字符集,避免依賴(lài)系統(tǒng)默認(rèn)編碼。 2.在網(wǎng)絡(luò)邊界處理字符串時(shí)確保兩端一致,設(shè)置正確的Content-Type頭並用庫(kù)顯式指定編碼。 3.謹(jǐn)慎使用String.getBytes()和newString(byte[]),應(yīng)始終手動(dòng)指定StandardCharsets.UTF_8以避免平臺(tái)差異導(dǎo)致的數(shù)據(jù)損壞??傊?,通過(guò)在每個(gè)階段

JavaScript數(shù)據(jù)類(lèi)型:原始與參考 JavaScript數(shù)據(jù)類(lèi)型:原始與參考 Jul 13, 2025 am 02:43 AM

JavaScript的數(shù)據(jù)類(lèi)型分為原始類(lèi)型和引用類(lèi)型。原始類(lèi)型包括string、number、boolean、null、undefined和symbol,其值不可變且賦值時(shí)復(fù)制副本,因此互不影響;引用類(lèi)型如對(duì)象、數(shù)組和函數(shù)存儲(chǔ)的是內(nèi)存地址,指向同一對(duì)象的變量會(huì)相互影響。判斷類(lèi)型可用typeof和instanceof,但需注意typeofnull的歷史問(wèn)題。理解這兩類(lèi)差異有助於編寫(xiě)更穩(wěn)定可靠的代碼。

Hashmap在Java內(nèi)部如何工作? Hashmap在Java內(nèi)部如何工作? Jul 15, 2025 am 03:10 AM

HashMap在Java中通過(guò)哈希表實(shí)現(xiàn)鍵值對(duì)存儲(chǔ),其核心在於快速定位數(shù)據(jù)位置。 1.首先使用鍵的hashCode()方法生成哈希值,並通過(guò)位運(yùn)算轉(zhuǎn)換為數(shù)組索引;2.不同對(duì)象可能產(chǎn)生相同哈希值,導(dǎo)致衝突,此時(shí)以鍊錶形式掛載節(jié)點(diǎn),JDK8後鍊錶過(guò)長(zhǎng)(默認(rèn)長(zhǎng)度8)則轉(zhuǎn)為紅黑樹(shù)提升效率;3.使用自定義類(lèi)作鍵時(shí)必須重寫(xiě)equals()和hashCode()方法;4.HashMap動(dòng)態(tài)擴(kuò)容,當(dāng)元素?cái)?shù)超過(guò)容量乘以負(fù)載因子(默認(rèn)0.75)時(shí),擴(kuò)容並重新哈希;5.HashMap非線程安全,多線程下應(yīng)使用Concu

Java中的'靜態(tài)”關(guān)鍵字是什麼? Java中的'靜態(tài)”關(guān)鍵字是什麼? Jul 13, 2025 am 02:51 AM

InJava,thestatickeywordmeansamemberbelongstotheclassitself,nottoinstances.Staticvariablesaresharedacrossallinstancesandaccessedwithoutobjectcreation,usefulforglobaltrackingorconstants.Staticmethodsoperateattheclasslevel,cannotaccessnon-staticmembers,

在C中使用std :: Chrono 在C中使用std :: Chrono Jul 15, 2025 am 01:30 AM

std::chrono在C 中用於處理時(shí)間,包括獲取當(dāng)前時(shí)間、測(cè)量執(zhí)行時(shí)間、操作時(shí)間點(diǎn)與持續(xù)時(shí)間及格式化解析時(shí)間。 1.獲取當(dāng)前時(shí)間使用std::chrono::system_clock::now(),可轉(zhuǎn)換為可讀字符串但係統(tǒng)時(shí)鐘可能不單調(diào);2.測(cè)量執(zhí)行時(shí)間應(yīng)使用std::chrono::steady_clock以確保單調(diào)性,並通過(guò)duration_cast轉(zhuǎn)換為毫秒、秒等單位;3.時(shí)間點(diǎn)(time_point)和持續(xù)時(shí)間(duration)可相互操作,但需注意單位兼容性和時(shí)鐘紀(jì)元(epoch)

什麼是Java的重新進(jìn)入? 什麼是Java的重新進(jìn)入? Jul 13, 2025 am 02:14 AM

ReentrantLock在Java中提供比synchronized更靈活的線程控制。 1.它支持非阻塞獲取鎖(tryLock())、帶超時(shí)的鎖獲?。╰ryLock(longtimeout,TimeUnitunit))和可中斷等待鎖;2.允許設(shè)置公平鎖,避免線程飢餓;3.支持多個(gè)條件變量,實(shí)現(xiàn)更精細(xì)的等待/通知機(jī)制;4.需手動(dòng)釋放鎖,必須在finally塊中調(diào)用unlock()以避免資源洩漏;5.適用於需要高級(jí)同步控制的場(chǎng)景,如自定義同步工具或複雜並發(fā)結(jié)構(gòu),但對(duì)簡(jiǎn)單互斥需求仍推薦使用synchro

See all articles