【Java类集】_Map接口使用的注意事项笔记(亲测实例)
来源:互联网 发布:linux所有版本 编辑:程序博客网 时间:2024/06/17 02:56
【Java类集】_Map接口使用的注意事项笔记(亲测实例)
分类: Java
【Java类集】_Map接口使用的注意事项笔记
本章目标:
掌握Map接口的输出操作
掌握Map接口中Key类的定义标准
Map接口输出
对于Map接口来说,其本身是不能直接使用迭代(例如:Iterator、foreach)来进行输出的,因为Map中每个位置存放的是一对值(key->value),而Iterator中每次只能找到一个值。所以,如果此时非要使用迭代进行输出的话,则必须按以下步骤完成(以Iterator输出方法为例):
1、将Map的实例通过entrySet()方法变为Set接口对象
2、通过Set接口实例为Iterator实例化
3、通过Iterator迭代输出,每个内容都是Map.Entry的对象
4、通过Map.Entry进行key->value的分离
但是,在操作前必须说明的,Map接口一般只作为查找使用,输出毕竟是少数。
输出:
zhinangtuan-->www.zhinangtuan.cn
mldn-->www.mldn.cn
mldnjava-->www.mldnjava.cn
第一种方式,使用Iterator完成。当然,在JDK1.5之后也可以使用foreach完成。
输出:
zhinangtuan-->www.zhinangtuan.cn
mldn-->www.mldn.cn
mldnjava-->www.mldnjava.cn
这两种输出形式最终实际上还是以Collection的形式输出,只是以Map.Entry作为内容的操作类型。
在Map中,可以使用任意的类型作为key和value,那么使用非系统类也可以。
此时,只是将自定义的类作为key,但是在取值的时候发现取不了了,返回结果为null,那么为什么之前的String可以,但是自定义的类不存在呢?
实际上,对于匹配过程来讲呢,有一个特点,即:对象要一样才可以将内容查询出来。
输出:
zhangsan
可是这样并不是解决问题的方法,因为不可能将Person的per对象到处带走啊,应该像String一样,可以使用匿名对象的形式找到内容。那么此时,实际上就需要按照与Set接口中判断重复元素方式一样,进行方法的覆写。
注意事项:直接使用非系统类作为key
如果要使用非系统类作为Map的key,则此类必须覆写Object类中的以下两个方法:
hashCode()
equals()
输出:
zhangsan
作为key,或者更准确的说是作为对象的时候,实际上是依靠hashCode()和equals()来判断两个匿名对象是否相等,这一点由系统内容自动完成。
总结:
1、Map可以使用迭代输出
Map->entrySet->Set->Iterator->Map.Entry->key和value
2、如果使用非系统类作为key,则一定保证覆写equals和hashCode()方法,否则无效。
本章目标:
掌握Map接口的输出操作
掌握Map接口中Key类的定义标准
Map接口输出
对于Map接口来说,其本身是不能直接使用迭代(例如:Iterator、foreach)来进行输出的,因为Map中每个位置存放的是一对值(key->value),而Iterator中每次只能找到一个值。所以,如果此时非要使用迭代进行输出的话,则必须按以下步骤完成(以Iterator输出方法为例):
1、将Map的实例通过entrySet()方法变为Set接口对象
2、通过Set接口实例为Iterator实例化
3、通过Iterator迭代输出,每个内容都是Map.Entry的对象
4、通过Map.Entry进行key->value的分离
但是,在操作前必须说明的,Map接口一般只作为查找使用,输出毕竟是少数。
- import java.util.HashMap;
- import java.util.Map;
- import java.util.Set;
- import java.util.Iterator;
- public class IteratorDemo04{
- public static void main(String args[]){
- Map<String,String> map = null;
- map = new HashMap<String,String>();
- map.put("mldn","www.mldn.cn");
- map.put("zhinangtuan","www.zhinangtuan.cn");
- map.put("mldnjava","www.mldnjava.cn");
- Set<Map.Entry<String,String>> allSet = null;
- allSet = map.entrySet();
- Iterator<Map.Entry<String,String>> iter = null;
- iter = allSet.iterator();
- while(iter.hasNext()){
- Map.Entry<String,String> me = iter.next();
- System.out.println(me.getKey()+"-->"+me.getValue());
- }
- }
- }
输出:
zhinangtuan-->www.zhinangtuan.cn
mldn-->www.mldn.cn
mldnjava-->www.mldnjava.cn
第一种方式,使用Iterator完成。当然,在JDK1.5之后也可以使用foreach完成。
- import java.util.HashMap;
- import java.util.Map;
- import java.util.Set;
- import java.util.Iterator;
- public class IteratorDemo04{
- public static void main(String args[]){
- Map<String,String> map = null;
- map = new HashMap<String,String>();
- map.put("mldn","www.mldn.cn");
- map.put("zhinangtuan","www.zhinangtuan.cn");
- map.put("mldnjava","www.mldnjava.cn");
- Set<Map.Entry<String,String>> allSet = null;
- for(Map.Entry<String,String> me:map.entrySet()){
- System.out.println(me.getKey()+"-->"+me.getValue());
- }
- }
- }
输出:
zhinangtuan-->www.zhinangtuan.cn
mldn-->www.mldn.cn
mldnjava-->www.mldnjava.cn
这两种输出形式最终实际上还是以Collection的形式输出,只是以Map.Entry作为内容的操作类型。
在Map中,可以使用任意的类型作为key和value,那么使用非系统类也可以。
- import java.util.Map;
- import java.util.HashMap;
- class Person{
- private String name;
- private int age;
- public Person(String name,int age){
- this.name = name;
- this.age = age;
- }
- public String toString(){
- return "姓名:"+this.name+";年龄:"+this.age;
- }
- }
- public class HashMapDemo05{
- public static void main(String args[]){
- Map<String,Person> map = null;
- map = new HashMap<String,Person>();
- map.put(new Person("张三",30),"zhangsan");//增加内容
- System.out.println(map.get(new Person("张三",30)));
- }
- }
此时,只是将自定义的类作为key,但是在取值的时候发现取不了了,返回结果为null,那么为什么之前的String可以,但是自定义的类不存在呢?
实际上,对于匹配过程来讲呢,有一个特点,即:对象要一样才可以将内容查询出来。
- import java.util.Map;
- import java.util.HashMap;
- class Person{
- private String name;
- private int age;
- public Person(String name,int age){
- this.name = name;
- this.age = age;
- }
- public String toString(){
- return "姓名:"+this.name+";年龄:"+this.age;
- }
- }
- public class HashMapDemo06{
- public static void main(String args[]){
- Map<Person,String> map = null;
- map = new HashMap<Person,String>();
- Person per = new Person("张三",30);
- map.put(per,"zhangsan");//增加内容
- System.out.println(map.get(per));
- }
- }
输出:
zhangsan
可是这样并不是解决问题的方法,因为不可能将Person的per对象到处带走啊,应该像String一样,可以使用匿名对象的形式找到内容。那么此时,实际上就需要按照与Set接口中判断重复元素方式一样,进行方法的覆写。
注意事项:直接使用非系统类作为key
如果要使用非系统类作为Map的key,则此类必须覆写Object类中的以下两个方法:
hashCode()
equals()
- import java.util.Map;
- import java.util.HashMap;
- class Person{
- private String name;
- private int age;
- public Person(String name,int age){
- this.name = name;
- this.age = age;
- }
- public String toString(){
- return "姓名:"+this.name+";年龄:"+this.age;
- }
- public boolean equals(Object obj){
- if(this==obj){
- return true;
- }
- if(!obj instanceof Person){
- return false;
- }
- Person per = (Person) obj;
- if(this.name.equals(per.name)&&this.age==per.age){
- return true;
- }else{
- return false;
- }
- }
- public int hashCode(){
- return this.name.hashCode()*this.age;
- }
- }
- public class HashMapDemo07{
- public static void main(String args[]){
- Map<Person,String> map = null;
- map = new HashMap<Person,String>();
- map.put(new Person("张三",30),"zhangsan");//增加内容
- System.out.println(map.get(new Person("张三",30)));
- }
- }
输出:
zhangsan
作为key,或者更准确的说是作为对象的时候,实际上是依靠hashCode()和equals()来判断两个匿名对象是否相等,这一点由系统内容自动完成。
总结:
1、Map可以使用迭代输出
Map->entrySet->Set->Iterator->Map.Entry->key和value
2、如果使用非系统类作为key,则一定保证覆写equals和hashCode()方法,否则无效。
0 0
- 【Java类集】_Map接口使用的注意事项笔记(亲测实例)
- 【Java类集】_Map接口使用的注意事项笔记(亲测实例)
- 【Java类集】_Map接口笔记(实例亲测)
- 【Java类集】_Map接口笔记(实例亲测)
- Java类集 _Map 接口的使用注意事项
- Java类集 _Map接口
- Java类集 _Map接口
- 【Java类集】_Set接口笔记(实例亲测)
- 【Java类集】_SortedSet接口笔记(实例亲测)
- 【Java类集】_Iterator接口笔记(实例亲测)
- 【Java类集】_ListIterator接口笔记(实例亲测)
- 【Java类集】_Set接口笔记(实例亲测)
- 【Java类集】_SortedSet接口笔记(实例亲测)
- 【Java类集】_Iterator接口笔记(实例亲测)
- 【Java类集】_ListIterator接口笔记(实例亲测)
- Java集合源码学习(20)_Map接口的实现HashMap
- Java集合源码学习(23)_Map的子接口ConcurrentMap
- 【Java类集】_List接口笔记(实例亲测)
- BZOJ 1507 NOI 2003 Editor Splay
- 【Java类集】_foreach及Enumeration接口笔记(实例亲测)
- 顺序栈实现 马踏棋盘
- 【Java类集】_Map接口笔记(实例亲测)
- centos 安装mysql
- 【Java类集】_Map接口使用的注意事项笔记(亲测实例)
- C语言运算符优先级
- 【Java类集】_IdentityHashMap类笔记
- 【Java类集】_SortedMap类笔记
- linux: Count Lines of Code
- 【Java类集】_属性类:Properties笔记
- 动态规划笔记
- 〖Java类集〗_范例讲解:一对多关系笔记
- Wikioi P1166 矩阵取数游戏