集合

可以使用集合的三个具体类HashSet、LinkedHashSet、TreeSet来创建集合

HashSet类

负载系数

当元素个数超过了容量与负载系数的乘积,容量就会自动翻倍

HashSet类可以用来存储互不相等的任何元素。考虑到效率的因素,添加到散列集中的对象必须以一种正确分散散列码的方式来实现hashCode方法。

如果两个对象相等,那么这两个对象的散列码必须一样。两个不相等的对象可能有相同的散列码

继承Collection接口,所以Collection中的所有方法,都可以用

例子:

LinkedHashSet类

LinkedHashSet用一个链表实现来扩展HashSet类,他支持对集合内的元素排序

HashSet中的元素是没有被排序的,而LinkedHashSet中的元素可以按照他们插入集合的顺序提取。

例子:

LinkedHashSet保持了元素插入时的顺序。

TreeSet类

例子:

public class TextTreeSet {
public static void main(String [] args) { Set<String> set = new HashSet<String>(); set.add("London");
set.add("Paris");
set.add("New York");
set.add("Zon"); TreeSet<String> treeSet = new TreeSet<String>(set); System.out.println("Sorted tree set : " + treeSet); System.out.println("first : " + treeSet.first()); System.out.println("last : " + treeSet.last()); System.out.println(treeSet.headSet("New York")); //输出New York 之前的数据 System.out.println(treeSet.tailSet("New York")); //输出 New York 之后的数据 System.out.println("小于: " + treeSet.lower("Paris")); //返回一个小于给定的元素
System.out.println("大于: " + treeSet.higher("New York")); //返回一个大于给定的元素
System.out.println("小于或等于: " + treeSet.floor("P")); //返回一个小于或等于给定的元素
System.out.println("大于或等于:" + treeSet.ceiling("P")); //返回一个大于或等于给定的元素 System.out.println("pollFirst: " + treeSet.pollFirst());
System.out.println("pollLast: " + treeSet.pollLast()); System.out.println("New tree set: " + treeSet); }
}

例子:

HashSet,LinkedHashSet和TreeSet有什么区别?

HashSet使用哈希表实现的,元素是无序的。添加、删除操作时间复杂度都是O(1)。TreeSet内部结构是一个树结构(红黑树),元素是有序的,添加、删除操作时间复杂度为O(log(n)),并且提供了first(), last(), headSet(), tailSet()等方法来处理有序集合。LinkedHashSet是介于HashSet 和 TreeSet之间,内部是一个双向链表结构,所以它的插入是有序的,时间复杂度是O(1)。

 
 
映射表

 

更新方法包括clear、put、putAll和remove,方法clear()从映射表中删除所有的条目。

方法put(K,V)为映射表中的指定的键和值添加条目,如果这个映射表原来就包含键的一个条目,这原来的值将被新的值所替代,并且返回与这个键相关联的原来的值

查询方法包括containsKey、containsValue、isEmpty和size。

LinkedHashMap类是用链表来实现来扩展HashMap类,他支持映射表中的条目的排序。HashMap没有顺序,而LinkedHashMap,元素可以按照插入的顺序来顺序排序,也可以按他们被最后一次访问时的顺序从最早到最晚排序,

TreeMap类在遍历排好顺序的键时是很高效的。键可以使用Comparable接口或Comparator接口来排序

例子:

LinkedHashMap如果使用了按访问顺序排序,那么被访问的,会放在映射表的末尾

三种映射表的使用情况

统计单词出现次数例子:

public class CountOccurentOfWords {

    public static void main(String [] args) {

        String text = "Good morning. have a good class. Have a good visits. Have fun!.";
Map<String, Integer> map = new TreeMap<>();
String [] words = text.split("[ \n\t\r.,;:?!(){}]"); for(int i=0; i<words.length; i++) {
String key = words[i].toLowerCase(); if(key.length() > 0) {
if(!map.containsKey(key)) {
map.put(key, 1);
}else {
int value = map.get(key);
value++;
map.put(key, value);
}
} } Set<Map.Entry<String, Integer>> wordSet = map.entrySet(); //调用entrySet()方法 可以返回一个Set集合
for(Map.Entry<String, Integer> s: wordSet) {
System.out.println(s.getKey() + " " + s.getValue());
}
}
}

单元素与不可变的合集和映射表

Java 集合和映射表的更多相关文章

  1. java中的映射表HashMap、TreeMap

    集(set)是集合(collection),集合不是集. HashMap是散列映射.TreeMap对键进行排序了. map的三个视图:键集.值集合.键/值集. Set<K> keySet( ...

  2. java基本类型映射表

  3. Java集合(1)一 集合框架

    目录 Java集合(1)一 集合框架 Java集合(2)一 ArrayList 与 LinkList Java集合(3)一 红黑树.TreeMap与TreeSet(上) java集合(4)一 红黑树. ...

  4. 浅谈JAVA集合框架

    浅谈JAVA集合框架 Java提供了数种持有对象的方式,包括语言内置的Array,还有就是utilities中提供的容器类(container classes),又称群集类(collection cl ...

  5. Java集合框架中Map接口的使用

    在我们常用的Java集合框架接口中,除了前面说过的Collection接口以及他的根接口List接口和Set接口的使用,Map接口也是一个经常使用的接口,和Collection接口不同,Map接口并不 ...

  6. Java 集合系列 15 Map总结

    java 集合系列目录: Java 集合系列 01 总体框架 Java 集合系列 02 Collection架构 Java 集合系列 03 ArrayList详细介绍(源码解析)和使用示例 Java ...

  7. 浅谈JAVA集合框架(转载)_常用的Vector和HashMap

    原作者滴着:http://www.cnblogs.com/eflylab/archive/2007/01/20/625237.html Java提供了数种持有对象的方式,包括语言内置的Array,还有 ...

  8. Thinking in Java——集合(Collection)

    一.ArrayList的使用(略) 二.容器的基本概念 (一).Collection是集合类的基本接口 主要方法: public interface Collection<E>{ bool ...

  9. Java 集合 持有引用 & WeakHashMap

    Java 集合 持有引用 & WeakHashMap @author ixenos 摘要:强引用.弱引用.WeakHashMap动态回收步骤 Reference引用对象 可获得的(reacha ...

随机推荐

  1. 【刷题】BZOJ 2407 探险

    Description 探险家小T好高兴!X国要举办一次溶洞探险比赛,获奖者将得到丰厚奖品哦!小T虽然对奖品不感兴趣,但是这个大振名声的机会当然不能错过! 比赛即将开始,工作人员说明了这次比赛的规则: ...

  2. 自学Linux Shell3.3-列表命令ls

    点击返回 自学Linux命令行与Shell脚本之路 3.3-列表命令ls ls命令用于显示文件目录列表,和Windows系统下DOS命令dir类似.当执行ls命令时,默认显示的只有非隐藏文件的文件名. ...

  3. ZJOI 2019 一试记

    没有心思做太多的铺述. $Day1$考完已经过去了几天,逐渐变得冷静下来,细碎的思绪也已经飘远,剩下一些难以忘怀的东西.$WC$以后一段时间的训练,本以为把状态找了回来,豪情壮志地出发,结果竟又是落魄 ...

  4. bzoj4518/luogu4072 征途(斜率优化dp)

    首先推一波公式: 设f[t][i]为第t天以i为结尾,这时已经算了的最小公差$*m^2$ 设s[i]为1到i的和 $$f[t][i]=min\{f[t-1][j]+m*(s[i]-s[j]-\frac ...

  5. HDU 1029 Ignatius and the Princess IV / HYSBZ(BZOJ) 2456 mode(思维题,~~排序?~~)

    HDU 1029 Ignatius and the Princess IV (思维题,排序?) Description "OK, you are not too bad, em... But ...

  6. 目标检测网络之 Mask R-CNN

    Mask R-CNN 论文Mask R-CNN(ICCV 2017, Kaiming He,Georgia Gkioxari,Piotr Dollár,Ross Girshick, arXiv:170 ...

  7. vue2.0 keep-alive最佳实践

    1.基本用法 vue2.0提供了一个keep-alive组件用来缓存组件,避免多次加载相应的组件,减少性能消耗 <keep-alive> <component> <!-- ...

  8. C# WinForm文章收集

    DataGridView 使用方法集锦 https://blog.csdn.net/zhaoyu_m69/article/details/70307934 关于DataGridView的一些操作(很全 ...

  9. java连接数据库读取数据出现乱码

    因为这是通用编码,像中国通常使用的GBK.GB2312.Big5等只是针对中文而言,但是对其他文字就不适用了,为了使得这个问题的解决具有文字编码通用性,所以我这里设定了UTF8这个编码. 编码一致性涉 ...

  10. 51job_selenium测试

    Python爬虫视频教程零基础小白到scrapy爬虫高手-轻松入门 https://item.taobao.com/item.htm?spm=a1z38n.10677092.0.0.482434a6E ...