黑马程序员——javaSE_集合框架-Map
来源:互联网 发布:封神演义 知乎 编辑:程序博客网 时间:2024/03/29 14:03
------- android培训、java培训、期待与您交流! ----------
Map:双列集合,存储的是键值对,而且保证键的唯一性
|——Hashtable:底层是哈希表数据结构,是线程同步的。不可以存储null键,null值。
|——HashMap:底层是哈希表数据结构,是线程不同步的。可以存储null键,null值。替代了Hashtable.
|——TreeMap:底层是二叉树结构,可以对map集合中的键进行指定顺序的排序。
1,添加。
put(key,value):当存储的键相同时,新的值会替换老的值,并将老值返回。如果键没有重复,返回null。
void putAll(Map);
2,删除。
void clear():清空
value remove(key) :删除指定键。
3,判断。
boolean isEmpty():
boolean containsKey(key):是否包含key
boolean containsValue(value) :是否包含value
4,取出。
int size():返回长度
value get(key) :通过指定键获取对应的值。如果返回null,可以判断该键不存在。当然有特殊情况,就是在hashmap集合中,是可以存储null键null值的。
Collection values():获取map集合中的所有的值。
5,想要获取map中的所有元素:
原理:map中是没有迭代器的,collection具备迭代器,只要将map集合转成Set集合,可以使用迭代器了。之所以转成set,是因为map集合具备着键的唯一性,其实set集合就来自于map,set集合底层其实用的就是map的方法。取出Map集合中的元素有两种方法
方法一:把Map集合转成Set集合,把所有的键取出到Set集合中,然后迭代Set集合,利用Map集合中的get(Object key)方法来取出所有的值
import java.util.HashMap;import java.util.Iterator;import java.util.Map;import java.util.Set;public class Test {public static void main(String[] args) {Map<Person,String> map = new HashMap<Person,String>();map.put(new Person("zhangsan",20), "shanghai");map.put(new Person("lisi",30), "beijing");Set<Person> set = map.keySet();Iterator<Person> it = set.iterator();while(it.hasNext()){Person p = it.next();String value = map.get(p);System.out.println(p.getName()+"::"+p.getAge()+"..."+value);}}}class Person{private String name;private int 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;}public Person(String name, int age) {super();this.name = name;this.age = age;}public int hashCode(){return name.hashCode()+age;}public boolean equals(Object obj){Person p = (Person)obj;return this.name.equals(p.name)&&this.age==p.age;}}方法二:用entrySet方法,把键值对的映射关系取出来
Entry接口是Map接口的内部接口
import java.util.HashMap;import java.util.Iterator;import java.util.Map;import java.util.Map.Entry;import java.util.Set;public class Test {public static void main(String[] args) {Map<Person,String> map = new HashMap<Person,String>();map.put(new Person("zhangsan",20), "shanghai");map.put(new Person("lisi",30), "beijing");Set<Entry<Person,String>> set = map.entrySet();Iterator<Entry<Person,String>> it = set.iterator();while(it.hasNext()){Entry<Person,String> en = it.next();Person key = en.getKey();String value = en.getValue();System.out.println(key.getName()+"::"+key.getAge()+"..."+value);}}}class Person{private String name;private int 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;}public Person(String name, int age) {super();this.name = name;this.age = age;}public int hashCode(){return name.hashCode()+age;}public boolean equals(Object obj){Person p = (Person)obj;return this.name.equals(p.name)&&this.age==p.age;}}
0 0
- 黑马程序员——javaSE_集合框架-Map
- 黑马程序员——javaSE_集合框架-Collection
- 黑马程序员——集合框架Map
- 黑马程序员——集合框架-Map、集合工具类
- 黑马程序员——集合框架4:Map集合
- 黑马程序员——【Java】集合框架——Map
- 黑马程序员——Java集合框架—Map
- 黑马程序员———集合框架之Map接口
- 黑马程序员——>第十六天<集合框架(Map)>
- 黑马程序员_java集合框架——Map
- 黑马程序员——集合框架之Map
- 黑马程序员——API集合框架-Set、Map
- 黑马程序员——集合框架(Map详解)
- 黑马程序员——集合框架(Map)
- 黑马程序员—Map集合
- 黑马程序员—Map集合
- 黑马程序员—Java集合框架(Map、HashMap、TreeMap)
- 黑马程序员:集合框架Map
- BC 64 Sum
- mysql监控脚本
- GPS坐标转换为百度地图坐标
- 计划扑克
- 15.2 显示和打印
- 黑马程序员——javaSE_集合框架-Map
- 网关
- Linux_文件系统&磁盘分区
- 制作图标小记
- Enterprise Architect之UML实践
- Construct Binary Tree from Preorder and Inorder Traversal
- 读《50 Android Hacks》笔记整理Hack 9~Hack 17
- Java集合之Set
- (NO.00004)iOS实现打砖块游戏(四):砖块类的实现