1.描述HashMap内部实现原理。
2.描述Hashset和HashMap的区别。
3.年级的集合使用Map的嵌套实现。
10班,每个班50人。
4.编程实现文本文件的复制。合理设计程序,得到缓冲区的大小的高效区间。
提示缓冲区设置1k开始,不超过10M。
------------------------------------------------------------------------------
1 HashMap从纵向看包括一个hashset类型的key集,一个collection的value集。横向看hashmap的本质是一个entry的hashset集合。在存储方式上hashmap底层实现了一个散列算法,散列是一种基于关键词的搜索算法,提升了hashmap的查找速度。hashmap的查找机制是先用对象的hashcode得出一个地址用equals比较地址中的链表的各个元素如果相同取出对应的value值。散列的实现机制是,重写对象的hashcode方法,object的hashcode算法是操作系统实现的,java给出了String的hashcode算法的实现(result*31叠加)。java在hashcode的基础之上用返回值>>>16和hashcode亦或将低十六位更加分散。分配地址到object[]中。
2,hashSet没有KV对的概念,底层是由hashmap实现的
3,Map<Integer,Map<Integer,String>> school=new HashMap<Integer,Map<Integer,String>>(); for(int i=1;i<=10;i++){ Map<Integer,String> classes=new HashMap<Integer,String>(); for(int j=1;j<=50;j++){ classes.put(j, i+j+""); } school.put(i, classes); }
4,FileReader reader=new FileReader("d:/a.txt");
char[] buffer=new char[1024]; FileWriter writer=new FileWriter("d:/b.txt"); int length=-1; while((length=reader.read(buffer))!=-1){ writer.write(buffer, 0, length); }