本文属原创,转载请注明出处:http://www.cnblogs.com/robinjava77/p/5456085.html (Robin)

Map

 import java.util.HashMap;
import java.util.Iterator;
import java.util.Map; /**
* Created by robin on 2016/4/12.
*
* @author robin
*/
public class MapTest { public static void main(String args[]){
traversalKey();
} /**
* 在不知道map keys 的情况下 遍历map的key和value
*
* 总结
* 1.仅需要键(keys) map.keySet()
* 2.仅需要值(values) map.values()
* 3.使用的语言版本低于java 5,或是打算在遍历时删除entries,必须使用方法三
* 4.键值都要使用方法二。
*/
public static void traversalKey(){
Map<String,String> map = new HashMap<String, String>();
map.put("1","a");
map.put("2","b");
map.put("3","c");
map.put("4","d");
map.put("5","e");
map.put("6","e");
/**第一种方法:keySet() 获取key值,通过key值get Value 效率最低!由key get value 耗时*/
for (String key:map.keySet()){
System.out.println("key:"+key+"--value:"+map.get(key));
}
/**第二种方法:Map.Entry 效率高于第一种,一般推荐这种写法*/
for(Map.Entry<String,String> entry:map.entrySet()){
System.out.println("key:"+entry.getKey()+"--value:"+entry.getValue());
}
/**第三种方法:Iterator遍历 这种遍历方法新旧java版本皆通用,在遍历删除map的key-value时,这是唯一可选择的方法*/
Iterator<Map.Entry<String, String>> entries = map.entrySet().iterator();
while (entries.hasNext()) {
Map.Entry<String, String> entry = entries.next();
System.out.println("Key = " + entry.getKey() + ", Value = " + entry.getValue());
}
/**扩展 直接获取map的所有value值*/
for(String value:map.values()){
System.out.println(value);
} }
}

List

 import java.util.ArrayList;
import java.util.Iterator;
import java.util.List; /**
* Created by robin on 2016/4/13.
* 关于list遍历有三种办法:①普通方法;②增强for循环;③iterator
* 效率 ①>③>②
*
* ①内部不锁定, 效率最高, 但是当写多线程时要考虑并发操作的问题
* ②内部实现是使用了③
* ③执行过程中会进行数据锁定, 性能稍差
*
* list遍历删除数据建议采用方法③,若采用方法①,请使用倒序遍历删除,详情参考:ordinaryDelDesc;
* 不可使用②进行遍历删除,会产生bug
* @author robin
*/
public class ListTest { public static void main(String args[]){
List<Student> stuList = initList();
/**
* 普通遍历方法
*/
for(int i= 0;i< stuList.size();i++){
Student stuShow = stuList.get(i);
// System.out.println("stuId:"+stuShow.getStuId()+"----stuName:"+stuShow.getName());
} System.out.println("----普通遍历方法----"); /**
* 增强for循环遍历
*/
for (Student stu:stuList){
// System.out.println("stuId:"+stu.getStuId()+"----stuName:"+stu.getName());
}
System.out.println("----增强for循环遍历----");
/**
* Iterator 遍历
*/
Iterator<Student> iterator = stuList.iterator();
while (iterator.hasNext()){
Student stuShow = iterator.next();
// System.out.println("stuId:"+stuShow.getStuId()+"----stuName:"+stuShow.getName());
}
System.out.println("----Iterator循环遍历----"); //list中删除元素方法
ordinaryDelAsc(initList());
System.out.println("----普通遍历正序删除----");
ordinaryDelDesc(initList());
System.out.println("----普通遍历倒序删除----");
// heighten(stuList);
iteratorDel(initList());
System.out.println("----Iterator循环遍历删除----");
} public static List<Student> initList(){
List<Student> stuList = new ArrayList<Student>();
Student stuA = new Student("10001","路飞");
stuList.add(stuA);
Student stuB = new Student("10002","索隆");
stuList.add(stuB);
Student stuC = new Student("10003","山治");
stuList.add(stuC);
Student stuD = new Student("10004","娜美");
stuList.add(stuD);
Student stuE = new Student("10005","罗宾");
stuList.add(stuE);
Student stuF = new Student("10006","乌索普--1号");
stuList.add(stuF);
Student stuJ = new Student("10007","弗兰奇");
stuList.add(stuJ);
Student stuH = new Student("10006","乌索普--2号");
stuList.add(stuH);
Student stuK = new Student("10008","乔巴");
stuList.add(stuK);
Student stuI = new Student("10006","乌索普--3号");
stuList.add(stuI);
Student stuM = new Student("10006","乌索普--4号");
stuList.add(stuM);
Student stuL = new Student("10009","布鲁克");
stuList.add(stuL);
return stuList;
} /**
* 普通遍历方法 正序 删除预期数据
* 这种方法存在bug:删除元素时涉及到数组元素的移动,遍历下标n的元素。
* 当前元素符合条件,执行删除操作,当前n位置的元素被删除,n+1位置的元素,移动到n位置上。
* 搜索光标却还是n,并未n-1,下次循环搜索时,会从下标n+1开始检索。
* 此时n+1位置的元素,原本是n+2的元素,那么此次循环遍历检索就会遗漏n+1位置的元素检查。
* 倘若n+1位置的元素符合删除条件,那么程序就将出现bug。
* 因为建议多用iterator进行遍历删除,如果非得使用普通循环遍历方法删除元素,请采用倒序的办法,详见ordinaryDesc
* @param stuList
*/
public static void ordinaryDelAsc(List<Student> stuList){
for(int i= 0;i< stuList.size();i++){
Student stuShow = stuList.get(i);
if(stuShow.getStuId().equals("10006")){
stuList.remove(stuShow);
}
}
System.out.println(listToString(stuList));
}
/**
* 普通遍历方法 倒序 删除预期数据
* @param stuList
*/
public static void ordinaryDelDesc(List<Student> stuList){
for(int i= stuList.size()-1;i>0 ;i--){
Student stuShow = stuList.get(i);
if(stuShow.getStuId().equals("10006")){
stuList.remove(stuShow);
}
}
System.out.println(listToString(stuList));
} /**
* 增强for循环遍历删除预期数据
* @param stuList
*/
public static void heighten(List<Student> stuList){
for (Student stu:stuList){
if(stu.getStuId().equals("10006")){
stuList.remove(stu);
}
}
System.out.println(listToString(stuList));
} /**
* Iterator 循环遍历删除预期数据
* @param stuList
* @return
*/
public static void iteratorDel(List<Student> stuList){
Iterator<Student> iterator = stuList.iterator();
while (iterator.hasNext()){
Student stuShow = iterator.next();
if(stuShow.getStuId().equals("10006")){
iterator.remove();
}
}
System.out.println(listToString(stuList));
} private static String listToString(List<Student> list){
StringBuilder sb = new StringBuilder("");
for (Student s:list){
sb.append("[stuId:"+s.getStuId()+"---name:"+s.getName()+"] \n");
}
return sb.toString();
} } class Student{ public Student(String stuId,String name){
this.stuId =stuId;
this.name = name;
} private String stuId; private String name; public void setStuId(String stuId){
this.stuId = stuId;
} public String getStuId(){
return this.stuId;
} public void setName(String name){
this.name = name;
} public String getName(){
return this.name;
}
}

map和list遍历基础的更多相关文章

  1. Java基础知识强化之集合框架笔记53:Map集合之Map集合的遍历 键值对对象找键和值

    1. Map集合的遍历(键值对对象找键和值) Map -- 夫妻对  思路:  A: 获取所有结婚证的集合  B: 遍历结婚证的集合,得到每一个结婚证  C: 根据结婚证获取丈夫和妻子 转换:  A: ...

  2. Java基础知识强化之集合框架笔记52:Map集合之Map集合的遍历 键找值

    1. Map集合的遍历  Map -- 夫妻对 思路:  A:把所有的丈夫给集中起来.  B:遍历丈夫的集合,获取得到每一个丈夫.  C:让丈夫去找自己的妻子.  转换:  A:获取所有的键  B:遍 ...

  3. Map三种遍历方式

    Map三种遍历方式 package decorator; import java.util.Collection; import java.util.HashMap; import java.util ...

  4. Map集合的遍历方式:

    迭代器来遍历 : entrySet() ; keySet(); values(); eg.HashMap<String,String> map = new HashMap<Strin ...

  5. Android(java)学习笔记105:Map集合的遍历之键值对对象找键和值

    package cn.itcast_01; import java.util.HashMap; import java.util.Map; import java.util.Set; /* * Map ...

  6. Android(java)学习笔记104:Map集合的遍历之键找值

    package cn.itcast_01; import java.util.HashMap; import java.util.Map; import java.util.Set; /* * Map ...

  7. Java中Map接口的遍历

    package Test4; import java.util.Collection;import java.util.HashMap;import java.util.Iterator;import ...

  8. 关于Map集合的遍历总结

    Map集合的遍历经常遇到,今天在这里总结一下Map集合遍历的几种方式: public static void main(String[] args){ Map<String,String> ...

  9. Android(java)学习笔记44:Map集合的遍历之键值对对象找键和值

    1. Map集合的遍历之 键值对对象找 键和值: package cn.itcast_01; import java.util.HashMap; import java.util.Map; impor ...

随机推荐

  1. Combination Sum

    Given a set of candidate numbers (C) (without duplicates) and a target number (T), find all unique c ...

  2. close-vs-shutdown-socke

    http://stackoverflow.com/questions/4160347/close-vs-shutdown-socket http://blog.csdn.net/jnu_simba/a ...

  3. js实现页面局部弹窗打印

    原文出自:http://www.haorooms.com/post/css3media 在网页中经常看到有打印功能,点击之后,只针对特定区域进行的打印.网上看了一下,大体上有2中实现方法,一种是用cs ...

  4. myeclipse激活时cracker2015.jar打不开

    myeclipse激活时cracker2015.jar打不开 可能是jdk版本的问题 这是我用的myeclipse版本 myeclipse-2016-ci-7-offline-installer-wi ...

  5. html引入css文件

    在HTML中,引入CSS的方法主要有行内式.内嵌式.导入式和链接式. 行内式:即在标记的style属性中设定CSS样式,这种方式本质上没有体现出CSS的优势,因此不推荐使用.例: <html&g ...

  6. 在CentOS中将/var等已有目录挂载到新添加的硬盘

    1.查看当前硬盘使用状况: [root@gluster_node1 ~]# df -h Filesystem            Size  Used Avail Use% Mounted on / ...

  7. D 最熟悉的陌生人 (纪念当年就读的梅州市江南高级中学)

    最熟悉的陌生人 作者:张慧桥 “蝶恋花” 我匆匆地跟听众道了声再见,手忙脚乱地关掉了机器,拿出手机按下了一个快捷键…… “嘟…嘟…” 电话响两下后,我听到了那个我在睡梦中都可以认出来的声音. “你现在 ...

  8. Kubernetes系统架构简介

    1. 前言 Together we will ensure that Kubernetes is a strong and open container management framework fo ...

  9. JMeter Webservice测试计划

    一.新建测试计划:HelloWorld测试计划 二.添加线程组 编辑线程组属性: 三.添加 SOAP/ XML-RPC 请求元素 四.填入url地址及请求报文 此处的请求报文,是用soapUI生成的, ...

  10. Python不完全入门指南

    适用范围: 有一定编程基础,想快速入门python的人群 说明: 使用jupyter notebook编写,可以使用nbviewer网站进行查看. Python不完全入门指南 项目放在github上, ...