繼續(xù)堅(jiān)持下去吧,各位騷年們!
事實(shí)上,我們的數(shù)據(jù)結(jié)構(gòu),只剩下這個(gè)Map的知識(shí)點(diǎn)了,平時(shí)開發(fā)中,也是能看到他的,所以還是非常值得去學(xué)習(xí)的1個(gè)知識(shí)點(diǎn)的,我們直接開車了
泛型< k,v> 鍵值對(duì),映照關(guān)系
基本特點(diǎn)
我們的學(xué)習(xí)步驟也是這樣來的,
Map有3個(gè)子類
Map和Set很像,其實(shí)Set底層就是使用了Map集合
我們看1下他們的共同點(diǎn)
package com.lgl.hellojava;
import java.util.Collection;
import java.util.HashMap;
import java.util.Map;
public class HelloJJAVA {
public static void main(String[] args) {
Map<String, String> map = new HashMap<String, String>();
// 添加元素
map.put("001", "zhangsan");
map.put("002", "lisi");
map.put("003", "wangwu");
System.out.println("原數(shù)據(jù):"+map);
// 判斷是不是存在002的key
System.out.println(map.containsKey("002"));
//刪除
System.out.println(map.remove("002"));
System.out.println("刪除后:"+map);
//獲得
System.out.println("獲得:"+map.get("001"));
//可以通過get方法的返回值來判斷1個(gè)鍵是不是存在
map.put(null, "haha");
System.out.println("null:"+map);
//獲得map集合中所有的值
Collection<String> values = map.values();
System.out.println("map的值:"+values);
}
}
這里可以看到輸出的結(jié)果
但是這里要注意的是,添加元素,如果添加的時(shí)候,相同的鍵,那末后面的,會(huì)被后添加的覆蓋原本的鍵對(duì)應(yīng)的值,并put方法會(huì)返回被覆蓋的值
想取出他的值,他并沒有迭代器,那我們的思路可以轉(zhuǎn)變1下拿到他的所有的鍵再去get不就能夠拿到鍵值對(duì)了,我們來看1下
package com.lgl.hellojava;
import java.util.HashMap;
import java.util.Iterator;
import java.util.Map;
import java.util.Set;
public class HelloJJAVA {
public static void main(String[] args) {
Map<String, String> map = new HashMap<String, String>();
map.put("001", "zhangsan");
map.put("002", "lisi");
map.put("003", "wangwu");
// 先獲得map集合中的所有鍵的Set集合
Set<String> keySet = map.keySet();
// 有了Set集合就能夠獲得迭代器
Iterator<String> iterator = keySet.iterator();
while (iterator.hasNext()) {
String string = iterator.next();
// 有了鍵可以通過map集合的get方法獲得其對(duì)應(yīng)的值
String value = map.get(string);
System.out.println("key:" + string + "values:" + value);
}
}
}
這類方法還是比較好理解的,對(duì)吧,但是這樣比較麻煩,我們來看另外一種
package com.lgl.hellojava;
import java.util.HashMap;
import java.util.Iterator;
import java.util.Map;
import java.util.Map.Entry;
import java.util.Set;
public class HelloJJAVA {
public static void main(String[] args) {
Map<String, String> map = new HashMap<String, String>();
map.put("001", "zhangsan");
map.put("002", "lisi");
map.put("003", "wangwu");
// 將map集合中的映照關(guān)系取出,存入到Set集合中
Set<Entry<String, String>> entrySet = map.entrySet();
Iterator<Entry<String, String>> iterator = entrySet.iterator();
while (iterator.hasNext()) {
Map.Entry<String, String> entry = iterator.next();
System.out.println(entry.getKey() + ":" + entry.getValue());
}
}
}
定義泛型雖然比較麻煩,但是取出來還是比較簡(jiǎn)單的,原理是甚么?其實(shí)我們可以寫1段偽代碼來講明的
package com.lgl.hello;
public class HashMap implements Map {
class Hahs implements Map.Entry {
@Override
public Object getKey() {
// TODO Auto-generated method stub
return null;
}
@Override
public Object getValue() {
// TODO Auto-generated method stub
return null;
}
}
}
interface Map {
public static interface Entry {
public abstract Object getKey();
public abstract Object getValue();
}
}
父子接口,直接訪問,內(nèi)部規(guī)則
我們可以通過1個(gè)小練習(xí)來學(xué)習(xí)1下使用規(guī)則,而需求,我直接寫在注釋上
package com.lgl.hellojava;
import java.util.HashMap;
import java.util.Iterator;
import java.util.Map.Entry;
import java.util.Set;
public class HelloJJAVA {
public static void main(String[] args) {
/**
* 每一個(gè)學(xué)生都有對(duì)應(yīng)的歸屬地 學(xué)生Student,地址String 學(xué)生屬性:姓名和年齡
* 注意:姓名和年齡相同的視為同1個(gè)學(xué)生,保證學(xué)生的唯1性
*
* 1.描寫學(xué)生 2.定義Map容器,將學(xué)生作為鍵,地址作為值存入 3.獲得Map容器中的元素
*/
HashMap<Student, String> hm = new HashMap<Student, String>();
hm.put(new Student("zhangsan", 15), "beijing");
hm.put(new Student("lisi", 16), "shanghai");
hm.put(new Student("wangwu", 17), "guangzhou");
hm.put(new Student("liliu", 10), "shenzhen");
// 第1種取出方式keySet
Set<Student> keySet = hm.keySet();
Iterator<Student> iterator = keySet.iterator();
while (iterator.hasNext()) {
Student student = iterator.next();
String addr = hm.get(student);
System.out.println(student + ":" + addr);
}
//第2種取出方式 entrySet
Set<Entry<Student, String>> entrySet = hm.entrySet();
Iterator<Entry<Student, String>> iterator2 = entrySet.iterator();
while (iterator2.hasNext()) {
Entry<Student, String> next = iterator2.next();
System.out.println(next.getKey()+":"+next.getValue());
}
}
}
/**
* 描寫學(xué)生
*
* @author LGL
*
*/
class Student implements Comparable<Student> {
private String name;
private int age;
public Student(String name, int age) {
this.name = name;
this.age = age;
}
@Override
public int hashCode() {
// TODO Auto-generated method stub
return name.hashCode() + age * 34;
}
@Override
public boolean equals(Object obj) {
if (!(obj instanceof Student))
throw new RuntimeException("類型不匹配");
Student s = (Student) obj;
return this.name.equals(s.name) && this.age == s.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 int compareTo(Student s) {
int num = new Integer(this.age).compareTo(new Integer(s.age));
if (num == 0)
return this.name.compareTo(s.name);
return num;
}
}
OK,例子就是用兩種取出的方式罷了,相信你自己也1定能做好的,好的,我們本節(jié)課到這里也就結(jié)束了,下節(jié)再見