集合的一个很重要的操做---遍历,学习了三种遍历方法,三种方法各有优缺点~~html
/*
* To change this template, choose Tools | Templates
* and open the template in the editor.
*/
package cn.tsp2c.liubao;java
import java.util.Collection;
import java.util.HashMap;
import java.util.Iterator;
import java.util.Map;
import java.util.Set;
import java.util.TreeMap;ide
/**
*
* @author Administrator
*/
public class TestMap {post
public static void main(String[] args) {
Map<String, Student> map = new HashMap<String, Student>();
Student s1 = new Student("宋江", "1001", 38);
Student s2 = new Student("卢俊义", "1002", 35);
Student s3 = new Student("吴用", "1003", 34);
map.put("1001", s1);
map.put("1002", s2);
map.put("1003", s3);学习
Map<String, Student> subMap = new HashMap<String, Student>();
subMap.put("1008", new Student("tom", "1008", 12));
subMap.put("1009", new Student("jerry", "1009", 10));
map.putAll(subMap);this
work(map);
workByKeySet(map);
workByEntry(map);
}url
//最常规的一种遍历方法,最常规就是最经常使用的,虽然不复杂,但很重要,这是咱们最熟悉的,就很少说了!!htm
public static void work(Map<String, Student> map) {
Collection<Student> c = map.values();
Iterator it = c.iterator();
for (; it.hasNext();) {
System.out.println(it.next());
}
}blog
//利用keyset进行遍历,它的优势在于能够根据你所想要的key值获得你想要的 values,更具灵活性!!get
public static void workByKeySet(Map<String, Student> map) {
Set<String> key = map.keySet();
for (Iterator it = key.iterator(); it.hasNext();) {
String s = (String) it.next();
System.out.println(map.get(s));
}
}
//比较复杂的一种遍历在这里,呵呵~~他很暴力哦,它的灵活性太强了,想获得什么就能获得什么~~
public static void workByEntry(Map<String, Student> map) {
Set<Map.Entry<String, Student>> set = map.entrySet();
for (Iterator<Map.Entry<String, Student>> it = set.iterator(); it.hasNext();) {
Map.Entry<String, Student> entry = (Map.Entry<String, Student>) it.next();
System.out.println(entry.getKey() + "--->" + entry.getValue());
}
}
}
class Student {
private String name;
private String id;
private int age;
public Student(String name, String id, int age) {
this.name = name;
this.id = id;
this.age = age;
}
@Override
public String toString() {
return "Student{" + "name=" + name + "id=" + id + "age=" + age + '}';
}
}
使人煎熬的周末又算熬过去了,比较轻松的周一开始了,蜗居在宿舍一上午,下午睡起来,没事作,决定看看这周学的东西,看了看io,看了看bufferedReader和bufferedWriter
很明显bufferedreader的用法比inputstream要复杂,复杂的存在必然会致使优点的存在!咱们都知道inputstream是一个字节一个字节的读取,每次读取都会执行一次IO,咱们知道io的操做是很费时间的,这就必然会致使程序的效率,而bufferedreader很好的解决这一问题,它能够一次读取大量的数据,大大减小了io次数,效率也就上去了,这就像有辆能乘坐一百人的大巴,从热力输送学生到理工本部,司机脑残,学生没睡醒,非要一次只坐一个同窗,大巴的来回跑一百趟才能把这一百人所有送到学校,这就相似inputstream,另外一个司机是清华毕业,智商固然高了,他让这一百人所有上车,一次九ok了,虽然在学生上车时多用了点时间,但总时间要远比那个脑残司机要少的多!!!固然在计算机中不会有这么大的时间差!!哔哔了这么多,应该表述清楚了,下面是一个bufferedreader的例子,本想写个关于bufferedreader比inputstream快的例子,多是本人人品太好了吧,运行的结果每次都是0毫秒~~~
package cn.tsp2s.liu.liubao;
import java.io.BufferedReader;
import java.io.BufferedWriter;
import java.io.FileNotFoundException;
import java.io.FileReader;
import java.io.FileWriter;
import java.io.IOException;
import java.util.logging.Level;
import java.util.logging.Logger;
/** * * @author Administrator */public class TestBufferedReader { public static void main(String[] args){ FileReader in=null; BufferedReader read=null; String s=null; BufferedWriter writer=null; try { in = new FileReader("d:\\java\\TestLeap.java"); read=new BufferedReader(in); writer=new BufferedWriter(new FileWriter("d:\\java\\leap.txt")); while ((s = read.readLine()) != null) { // System.out.println(s); writer.write(s); //这里调用newline()方法是让它输出和读取的彻底一致,理由不解释 writer.newLine(); //这里必定要调用flush()方法,若是不调用,文件中将会显示不全或者压根就不显示任何东西,理由不解释,你确定知道 writer.flush(); } } catch (FileNotFoundException ex) { System.out.println("找不到指定文件!!"); }catch (IOException e) { System.out.println("文件读取有误!"); }finally{ try { writer.close(); read.close(); } catch (IOException ex) { System.out.println(ex.getMessage()); } } }}