IT十八掌作业_java基础第十二天_集合

1.描述HashMap内部实现原理。

HashMap 存储的是key - value 键值对,key不能重复,无序的。

使用put方法存放数据,存放时通过hash(key)%len来决定存放位置,

主要通过A.hashcode==B.hashcode&&(this == obj||A.equals(B))来判断是否同一个对象,

比较链上的每个对象,如果没有相同,就放入到链尾,如果该链上无对象,直接放入。



2.描述Hashset和HashMap的区别。

两者实际上并无区别,HashSet内部就是使用HashMap实现,只不过HashSet里面的HashMap所有的value都是同一个Object而已。


3.年级的集合使用Map的嵌套实现。

  10班,每个班50人。


package com.it18zhang.hash.demo;


import java.util.HashMap;

import java.util.Iterator;

import java.util.Map;

import java.util.Map.Entry;


public class SchoolDemo {


public static void main(String[] args) {

Map<Integer,Map<String,String>> school = new HashMap<Integer,Map<String,String>>();

Map<String,String> className=null;

for (int i = 1; i <= 10; i++) {

className = new HashMap<String,String>();

for (int j = 1; j <= 50; j++) {

className.put("C"+i+"."+j, "Tom"+((i-1)*50+j));

}

school.put(i,className);

}

System.out.println("------输出----entrySet方式 ----------" );

for(Entry<Integer,Map<String,String>> enties:school.entrySet()){

Integer key = enties.getKey();

Map<String,String> values = enties.getValue();

for(Entry<String,String>entry0 : values.entrySet()){

String stuNo = entry0.getKey();

String stuName = entry0.getValue();

System.out.println(key + "=>" + stuNo + "=>" + stuName );

}

}

System.out.println("----输出------Iterator方式 ----------" );

Iterator<Entry<Integer, Map<String, String>>> it = school.entrySet().iterator();

while(it.hasNext()){

Entry<Integer,Map<String,String>> entries = (Entry<Integer,Map<String,String>>)it.next();

Integer key = entries.getKey();

Map<String,String> values = entries.getValue();

for(Entry<String,String> e0:values.entrySet()){

String stuNo= e0.getKey();

String stuName = e0.getValue();

System.out.println(key + "=>" + stuNo + "=>" + stuName );

}

}

System.out.println("----输出------keySet方式 ----------" );

for(Integer key:school.keySet()){

Map<String,String> cName = school.get(key);

for(String stuNo:cName.keySet()){

String stuName = cName.get(stuNo);

System.out.println( "=>" + stuNo + "=>" + stuName );

}

}

}


}


4.编程实现文本文件的复制。合理设计程序,得到缓冲区的大小的高效区间。

  提示缓冲区设置1k开始,不超过10M。

package com.it18zhang.io.demo;


import java.io.FileReader;

import java.io.FileWriter;


public class CopyFileDemo {


public static void main(String[] args) throws Exception {

FileReader fr = new FileReader("d:/aa.txt");

FileWriter fw = new FileWriter("d:/bb.txt");

char[] buf = new char[1024];

int len= 0;

while((len = fr.read(buf))!= -1){

fw.write(buf, 0, len);

}

fw.close();

fr.close();

}


}


你可能感兴趣的:(java,基础,集合)