标签:Map Java map System put println out
Java学习之Map
Map接口简介
- Map对象是一种双列集合,每一个元素都是一组键值对(键对象和值对象)
- 键值对之间存在的关系称为映射,Map中的映射是一对一的,根据键可以找到与之对应的值对象
- Map中的Key对象和Value对象可以是任意数据类型,但是必须确保键值是唯一的
HashMap集合
- HashMap集合是Map接口的一个实现类,该集合的键值允许为空,但键不能为重复,而且集合中的元素是无序的
- HashMap底层是由哈希表结构组成的,其实就是数组加链表的组合,数组是HashMap的主体结构,链表只是为了解决Hash的寻址冲突
- 由于特殊的底层结构,它增删改查的效率都比较高
Demo
package com.tang.chapter6.map;
import java.util.HashMap;
import java.util.Map;
/**
* @author Tang
*/
public class Demo01 {
public static void main(String[] args) {
Map<String,String> map = new HashMap<String, String>();
map.put("1","zs");
map.put("2","ls");
map.put("3","ww");
map.put("4","ll");
System.out.println("Map集合" + map);
System.out.println("是否包含键对象1:" + map.containsKey("1"));
System.out.println("是否包含值对象zs:" + map.containsValue("zs"));
System.out.println("获取所有的键对象:" + map.keySet());
System.out.println("获取所有的值对象:" + map.values());
System.out.println("获取键对象1的值:" + map.get("1"));
map.replace("1","hello world");
System.out.println("修改键对象1的值:" + map.get("1") );
System.out.println(map);
System.out.println("删除键对象1的值:" + map.remove("1"));
System.out.println(map);
}
}
Map集合遍历
-
使用迭代器遍历
- KeySet()方法
public class Demo01 { public static void main(String[] args) { Map<String,String> map = new HashMap<String, String>(); map.put("1","zs"); map.put("2","ls"); map.put("3","ww"); map.put("4","ll"); System.out.println(map); Set<String> keySet = map.keySet(); Iterator<String> iterator = keySet.iterator(); while (iterator.hasNext()){ Object key = iterator.next(); Object value = map.get(key); System.out.println(key + ":" + value); } } }
- EntrySet()方法
public class Demo01 { public static void main(String[] args) { Map<String,String> map = new HashMap<String, String>(); map.put("1","zs"); map.put("2","ls"); map.put("3","ww"); map.put("4","ll"); System.out.println(map); Set<Map.Entry<String, String>> entrySet = map.entrySet(); Iterator<Map.Entry<String, String>> iterator = entrySet.iterator(); while (iterator.hasNext()){ Map.Entry entry = (Map.Entry)(iterator.next()); Object key = entry.getKey(); Object value = entry.getValue(); System.out.println(key+":"+value); } }
-
说明一点:EntrySet方法比KeySet方法要快一点
-
使用foreach方法遍历集合
public class Demo01 {
public static void main(String[] args) {
Map<String,String> map = new HashMap<String, String>();
map.put("1","zs");
map.put("2","ls");
map.put("3","ww");
map.put("4","ll");
System.out.println(map);
map.forEach((key,value) -> System.out.println(key+ ":" +value));
// 遍历集合的Value值
Collection<String> values = map.values();
values.forEach(System.out::println);
}
}
标签:Map,Java,map,System,put,println,out 来源: https://www.cnblogs.com/laomaocode/p/15106890.html
本站声明: 1. iCode9 技术分享网(下文简称本站)提供的所有内容,仅供技术学习、探讨和分享; 2. 关于本站的所有留言、评论、转载及引用,纯属内容发起人的个人观点,与本站观点和立场无关; 3. 关于本站的所有言论和文字,纯属内容发起人的个人观点,与本站观点和立场无关; 4. 本站文章均是网友提供,不完全保证技术分享内容的完整性、准确性、时效性、风险性和版权归属;如您发现该文章侵犯了您的权益,可联系我们第一时间进行删除; 5. 本站为非盈利性的个人网站,所有内容不会用来进行牟利,也不会利用任何形式的广告来间接获益,纯粹是为了广大技术爱好者提供技术内容和技术思想的分享性交流网站。