So sánh hashmap và treemap trong java
Các entry trong HashMap không được sắp xếp theo thứ tự. Nhưng nếu bạn bị yêu cầu phải sắp xếp thì bạn hoàn toàn có thể làm được. Show
Sắp xếp HashMap dựa trên các Keys khá là dễ. Chúng ta có 2 cách làm. Cách 1: Dùng TreeMap (ưu tiên dùng cách này) Việc bạn cần làm là tạo ra một TreeMap bằng cách sao chép các entries từ HashMap. TreeMap là một implementation của SortedMap. Vì vậy nó sẽ sắp xếp theo natural ordering hoặc bạn hoàn toàn có thể custom việc sắp xếp theo ý bạn bằng cách dùng Comparator. Cách 2: Dùng LinkedHashMap Cách này hơi dài dòng chút. Đầu tiên bạn cần lấy ra một Set các keys. Convert Set đó thành List. Sắp xếp List đó, và rồi add chúng lại LinkedHashMap theo đúng thứ tự đã sắp xếp. 2. Sắp xếp HashMap dựa trên ValueSắp xếp dựa trên Value khá phức tạp vì không có phương pháp trực tiếp hỗ trợ việc này. Bạn buộc phải viết code cho nó. Đầu tiên bạn phải tạo ra một Comparator để so sánh hai entries dựa trên value. Sau đó lấy Set of entries từ Map, convert Set thành List và dùng phương thức Cuối cùng, chúng ta tạo ra một LinkedHashMap, đây là một lớp extend từ HashMap và add các entries đã được sắp xếp vào đó. LinkedHashMap sẽ đảm bảo các phần tử được chèn vào theo một thứ tự 😉 Nội dung Đặc điểmNhững điểm quan trọng về lớp TreeMap trong java cần nhớ là:
Hierarchy của lớp TreeMapLớp java.util.TreeMap được định nghĩa như sau: public class TreeMap Trong đó:
Các phương thức khởi tạo (constructor) của lớp TreeMap
Các phương thức (method) của lớp TreeMapXem thêm các phương thức của Map ở bài viết Map Interface trong java. Ví dụ minh họaVí dụ sử dụng TreeMap với kiểu dữ liệu cơ bản (Wrapper)package com.gpcoder.collection.treemap; import java.util.Map; import java.util.Map.Entry; import java.util.TreeMap; public class LinkedHashMapExample { public static void main(String args[]) { }
}Kết quả thực thi chương trình trên: 1 = Basic java 2 = OOP 3 = Collection 4 = Multi-Thread 1 = Basic java 2 = OOP 3 = Collection 4 = Multi-Thread Ví dụ sử dụng TreeMap với key có kiểu String, value có kiểu Studentpackage com.gpcoder.collection.map; public class Student { private int id; private String name; public Student(int id, String name) { }
@Override
public String toString() { }
public int getId() { }
public String getName() { }
}package com.gpcoder.collection.treemap; import java.util.Map; import java.util.Map.Entry; import java.util.TreeMap; public class LinkedHashMapExample2 { public static void main(String args[]) { }
}Kết quả thực thi chương trình trên: 1 = Student [id=1, name=Student 1] 2 = Student [id=2, name=Student 2] 3 = Student [id=3, name=Student 3] 4 = Student [id=4, name=Student 4] 1 = Student [id=1, name=Student 1] 2 = Student [id=2, name=Student 2] 3 = Student [id=3, name=Student 3] 4 = Student [id=4, name=Student 4] Chuyên mục: Collection Được gắn thẻ: Collection Bình luậnbình luận |