Collection 接口每次只能保存一个对象,Map 接口每次保存一对对象。
使用 Collection 接口的主要目的是信息的输出,使用 Map 接口的主要目的是信息的查找。
使用 HashMap 定义的 Map 集合是无序存放的。
如果出现了重复的 Key 会进行覆盖,使用新的内容代替旧的内容。
Map 接口一般采用 HashMap 子类实现。
Hashtable 子类是Java1推出的,同步处理,线程安全,效率低,不允许 key 或者 value 的值为null。
HashMap 子类是Java2推出的,异步处理,非线程安全,效率高,允许 key 或者 value 的值为null。
Map 集合要想使用 Iterator 接口输出,必须使用 entrySet 方法将 Map 集合转换为 Set 集合。
使用 Map 集合时,首选 key 的类型是 String,尽量不采用自定义的类型。如果要使用自定义的类,那这个类必须要覆写 hashCode 和 equals 方法,因为只有靠这两个方法才能确定元素是否重复,而在 Map 中指的是能否找到元素。
import java.util.*;
class Book{
private String title;
private int price;
public Book(String title, int price){
this.title = title;
this.price = price;
}
@Override
public String toString() {
return this.title + " " + this.price;
}
@Override
public int hashCode() {
return Objects.hash(title, price);
}
@Override
public boolean equals(Object obj) {
if (this == obj) {
return true;
}
if (obj == null || getClass() != obj.getClass()) {
return false;
}
final Book other = (Book) obj;
return Objects.equals(this.title, other.title)
&& Objects.equals(this.price, other.price);
}
}
public class Main {
public static void main(String[] args) throws Exception{
// 设置了泛型,从而保证集合中所有的数据类型都一致
Book bookA = new Book("java",100);
Book bookB = new Book("c",89);
Book bookC = new Book("c++",100);
Book bookD = new Book("python",100);
Map <String,Book> map = new HashMap <String, Book>();
map.put("A",bookA);
map.put("B",bookB);
map.put("C",bookC);
map.put("D",bookD);
System.out.println(map);
System.out.println(map.get("A"));
Set <String> set = map.keySet();
Iterator <String> iterator = set.iterator();
while (iterator.hasNext()){
System.out.println(iterator.next());
}
Set <Map.Entry <String,Book>> set1 = map.entrySet();
Iterator <Map.Entry <String,Book>> iterator1 = set1.iterator();
while (iterator1.hasNext()){
System.out.println(iterator1.next().getKey() + " = " +iterator1.next().getValue());
}
}
}