詳解Java LinkedHashMap與HashMap的使用
HashMap存儲自定義類型鍵值
練習:每位學生(姓名,年齡)都有自己的家庭住址。那么,既然有對應關(guān)系,則將學生對象和家庭住址存儲到map集合中。學生作為鍵, 家庭住址作為值。
注意,學生姓名相同并且年齡相同視為同一名學生。
編寫學生類:
public class Student { private String name; private int age; public Student() { } public Student(String name, int age) { this.name = name; this.age = age; } public String getName() { return name; } public void setName(String name) { this.name = name; } public int getAge() { return age; } public void setAge(int age) { this.age = age; } @Override public boolean equals(Object o) { if (this == o) return true; if (o == null || getClass() != o.getClass()) return false; Student student = (Student) o; return age == student.age && Objects.equals(name, student.name); } @Override public int hashCode() { return Objects.hash(name, age); } }
編寫測試類:
public class HashMapTest { public static void main(String[] args) { //1,創(chuàng)建Hashmap集合對象。 Map<Student,String>map = new HashMap<Student,String>(); //2,添加元素。 map.put(newStudent("lisi",28), "上海"); map.put(newStudent("wangwu",22), "北京"); map.put(newStudent("zhaoliu",24), "成都"); map.put(newStudent("zhouqi",25), "廣州"); map.put(newStudent("wangwu",22), "南京"); //3,取出元素。鍵找值方式 Set<Student>keySet = map.keySet(); for(Student key: keySet){ Stringvalue = map.get(key); System.out.println(key.toString()+"....."+value); } } }
- 當給HashMap中存放自定義對象時,如果自定義對象作為key存在,這時要保證對象唯一,必須復寫對象的hashCode和equals方法(如果忘記,請回顧HashSet存放自定義對象)。
- 如果要保證map中存放的key和取出的順序一致,可以使用
java.util.LinkedHashMap
集合來存放。
LinkedHashMap
我們知道HashMap保證成對元素唯一,并且查詢速度很快,可是成對元素存放進去是沒有順序的,那么我們要保證有序,還要速度快怎么辦呢? 在HashMap下面有一個子類LinkedHashMap,它是鏈表和哈希表組合的一個數(shù)據(jù)存儲結(jié)構(gòu)。
public class LinkedHashMapDemo { public static void main(String[] args) { LinkedHashMap<String, String> map = new LinkedHashMap<String, String>(); map.put("青菜", "蘿卜"); map.put("紅花", "綠葉"); map.put("美景", "佳人"); Set<Entry<String, String>> entrySet = map.entrySet(); for (Entry<String, String> entry : entrySet) { System.out.println(entry.getKey() + " " + entry.getValue()); } } }
結(jié)果:
青菜 蘿卜
紅花 綠葉
美景 佳人
Map集合練習
需求: 計算一個字符串中每個字符出現(xiàn)次數(shù)。 分析:
- 獲取一個字符串對象
- 創(chuàng)建一個Map集合,鍵代表字符,值代表次數(shù)。
- 遍歷字符串得到每個字符。
- 判斷Map中是否有該鍵。
- 如果沒有,第一次出現(xiàn),存儲次數(shù)為1;如果有,則說明已經(jīng)出現(xiàn)過,獲取到對應的值進行++,再次存儲。
- 打印最終結(jié)果
代碼:
public class MapTest { public static void main(String[] args) { //友情提示 System.out.println("請錄入一個字符串:"); String line = new Scanner(System.in).nextLine(); // 定義 每個字符出現(xiàn)次數(shù)的方法 findChar(line); } private static void findChar(String line) { //1:創(chuàng)建一個集合 存儲 字符 以及其出現(xiàn)的次數(shù) HashMap<Character, Integer> map = new HashMap<Character, Integer>(); //2:遍歷字符串 for (int i = 0; i < line.length(); i++) { char c = line.charAt(i); //判斷 該字符 是否在鍵集中 if (!map.containsKey(c)) {//說明這個字符沒有出現(xiàn)過 //那就是第一次 map.put(c, 1); } else { //先獲取之前的次數(shù) Integer count = map.get(c); //count++; //再次存入 更新 map.put(c, ++count); } } System.out.println(map); } }
JDK9對集合添加的優(yōu)化
通常,我們在代碼中創(chuàng)建一個集合(例如,List 或 Set ),并直接用一些元素填充它。 實例化集合,幾個 add方法 調(diào)用,使得代碼重復。
public class Demo01 { public static void main(String[] args) { List<String> list = new ArrayList<>(); list.add("abc"); list.add("def"); list.add("ghi"); System.out.println(list); } }
Java 9,添加了幾種集合工廠方法,更方便創(chuàng)建少量元素的集合、map實例。新的List、Set、Map的靜態(tài)工廠方法可以更方便地創(chuàng)建集合的不可變實例。 例子:
public class HelloJDK9 { public static void main(String[] args) { Set<String> str1=Set.of("a","b","c"); //str1.add("c");這里編譯的時候不會錯,但是執(zhí)行的時候會報錯,因為是不可變的集合 System.out.println(str1); Map<String,Integer> str2=Map.of("a",1,"b",2); System.out.println(str2); List<String> str3=List.of("a","b"); System.out.println(str3); } }
需要注意以下兩點:
of()方法只是Map,List,Set這三個接口的靜態(tài)方法,其父類接口和子類實現(xiàn)并沒有這類方法,比如 HashSet,ArrayList等待;
返回的集合是不可變的;
到此這篇關(guān)于詳解Java LinkedHashMap與HashMap的使用的文章就介紹到這了,更多相關(guān)Java LinkedHashMap HashMap內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
Spring-webflux訪問關(guān)系型數(shù)據(jù)庫實戰(zhàn)
這篇文章主要為大家介紹了Spring-webflux訪問關(guān)系型數(shù)據(jù)庫實戰(zhàn)詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進步,早日升職加薪2023-07-07使用Java反射機制提高SpringBoot的代碼質(zhì)量和可維護性
保持好的代碼質(zhì)量和遵守編碼標準是開發(fā)可維護和健壯軟件的重要方面,在本文中,我們將探討如何使用 Java 反射來提高 Spring Boot 應用程序的代碼質(zhì)量和可維護性,需要的朋友可以參考下2023-10-10JDBC連接MySQL數(shù)據(jù)庫批量插入數(shù)據(jù)過程詳解
這篇文章主要介紹了JDBC連接MySQL數(shù)據(jù)庫批量插入數(shù)據(jù)過程詳解,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友可以參考下2019-11-11