JDK1.6新特性,基础类库篇,集合框架(Collections)
2006 年底,Sun 公司发布了 Java Standard Edition 6(Java SE 6)的最终正式版,代号 Mustang(野马)。
集合框架增强如下:
1. 增加了如下新接口(Interface)
- Deque - 一个双端队列,支持元素从双端插入与移除。从Queue接口继承而来。
- BlockingDeque - 一个队列当获取元素时如果队列为空则阻塞以等待;当插入时等待队列有空间可用。继承自Deque接口,此接口类属于java.util.concurrent包。
- NavigableSet - 一个可导航的继承于SortedSet接口的Set。 它可以按正序或倒序访问,此接口意图取代SortedSet接口。
- NavigableMap - 一个可导航的继承于SortedMap的Map。它可以对键(key)按正序或倒序访问,此接口意图取代SortedMap接口。
- ConcurrentNavigableMap - 一个继承于ConcurrentMap接口与NavigableMap接口的接口(它类属于java.util.concurrent包)。
2. 增加了如下实体类(classes)
- ArrayDeque - 一个高效的可伸缩的,由数组实现Deque接口的实现类。
- ConcurrentSkipListSet - 一个可缩放并发的NavigableSet接口实现类。
- ConcurrentSkipListMap - 一个可缩放并发的ConcurrentNavigableMap接口实现类。
- LinkedBlockingDeque - 一个由链表实现的可缩放并发的FIFO阻塞队列。
- AbstractMap.SimpleEntry - 一个简单易变的Map.entry实现。
- AbstractMap.SimpleImmutableEntry - 一个简单不变的Map.Entry实现。
3. 下列已经存在的类获得改良
- LinkedList - 改良发实现Deque接口。
- TreeSet - 改良以实现NavigableSet接口。
- TreeMap - 改良以实现NavigableMap接口。
4. Collections工具类增加方法
- newSetFromMap(Map) - 返回指定映射支持的 set。得到的 set 与底层实现映射有相同的顺序、并发性和性能特征。可以通过如下代码实现类似于IdentityHashSet这样的功能:
Set<Object> identityHashSet = Collections.newSetFromMap(new IdentityHashMap<Object, Boolean>());
- asLifoQueue(Deque) - 以后进先出 (Lifo) Queue 的形式返回某个 Deque 的视图。
5. Arrays工具类增加方法
Arrays工具类现在有方法copyOf和copyOfRange,可以复制指定的数组,截取或用 0 填充(如有必要),以使副本具有指定的长度;可以将指定数组的指定范围复制到一个新数组。
之前:
int[] newArray = new int[newLength];
System.arraycopy(oldArray, 0, newArray, 0, oldArray.length);
现在:
int[] newArray = Arrays.copyOf(a, newLength);
6. 总结
Java集合框架(Java Collections Framework)加入了一个新的NavigableMap和NavigableSet接口。分别的扩展了SortedMap和SortedSet接口,本质上添加了搜索选项到接口。
在Java 6中,这里有两个NavigableMap接口的实现。旧的TreeMap被改良以实现NavigableMap接口;另外,一个该接口的并发的版本现在可以在ConcurrentSkipListMap类中找到。可能你并不熟悉skiplist,它们是一种排序过的链接,使用了 并行链表提高了搜索的速度。但TreeMap的结构是平衡的,并且粗略的从链表中寻找一个键,ConcurrentSkipListMap一直都是从最前面开始,但是由于副skiplist的作用,搜索的效果很接近于二分查找。
最大的改变是,更好的双向集合存取访问(Deque接口等)。
NavigableMap/NavigableSet示范代码:
package com.clzhang.sample.thinking; import java.util.Map;
import java.util.NavigableMap;
import java.util.NavigableSet;
import java.util.SortedMap;
import java.util.TreeMap;
import java.util.TreeSet; import org.junit.Test; public class JDK16Navigable {
@Test
public void testMap() {
NavigableMap<Double, Integer> map = new TreeMap<Double, Integer>(); map.put(1.1, 1);
map.put(2.2, 2);
map.put(3.3, 3);
map.put(4.4, 4); // 小于该key且离该key最近的一个key
Double lowerKey = map.lowerKey(2.0);
System.out.println("lowerKey():" + lowerKey); // 大于该key且离该key最近的一个entry
Map.Entry<Double, Integer> entry = map.higherEntry(2.0);
System.out.println("higherEntry() key:" + entry.getKey() + " value:" + entry.getValue()); // 小于等于该key且离该key最近的一个key
Double floorKey = map.floorKey(2.2);
System.out.println("floorKey():" + floorKey); // 大于等于该key且离该key最近的一个key
Double ceilingKey = map.ceilingKey(2.0);
System.out.println("ceilingKey():" + ceilingKey); // 小于该key的一个Map
SortedMap<Double, Integer> headMap = map.headMap(2.0);
System.out.println("headMap():" + headMap); // 大于等于该key的一个Map
SortedMap<Double, Integer> tailMap = map.tailMap(2.0);
System.out.println("tailMap():" + tailMap); // 简单的不用使用迭代器而遍历所有Map元素的方法;也可以使用pollLastEntry()获取倒序输出。
Map.Entry<Double, Integer> entryEach = null;
while ((entryEach = map.pollFirstEntry()) != null) {
System.out.println("pollFirstEntry():" + entryEach.getKey() + entryEach.getValue());
}; System.out.println("-------------------------");
} @Test
public void testSet() {
NavigableSet<Integer> set = new TreeSet<Integer>();
set.add(1001);
set.add(1002);
set.add(1003);
set.add(1004); // 小于
Integer lower = set.lower(1003);
System.out.println("lower:" + lower); // 小于等于
Integer floor = set.floor(1003);
System.out.println("floor:" + floor); // 迭代,也可以使用pollFirst()获取正序输出。
Integer integer1 = null;
while ((integer1 = set.pollLast()) != null) {
System.out.println("pollFirst():" + integer1);
} System.out.println("-------------------------");
}
}
JDK1.6新特性,基础类库篇,集合框架(Collections)的更多相关文章
- JDK1.5新特性,语言篇
Java 1.5版本,就是Java 2 Standard Edition 5,Version 1.5,简称Java 5.版本代号Tiger. 一. 泛型(Generics) C++通过模板技术可以指定 ...
- JDK1.7新特性,语言篇
1. 可以用二进制表达数字 可以用二进制表达数字(加前缀0b/0B),包括:byte, short, int, long // 可以用二进制表达数字(加前缀0b/0B),包括:byte, short, ...
- JDK1.5新特性,基础类库篇,集合框架(Collections)
集合框架在JDK1.5中增强特性如下: 一. 新语言特性的增强 泛型(Generics)- 增加了集合框架在编译时段的元素类型检查,节省了遍历元素时类型转换代码量. For-Loop循环(Enhanc ...
- JavaSE----API之集合(Collection、List及其子类、Set及其子类、JDK1.5新特性)
5.集合类 集合类的由来: 对象用于封装特有数据,对象多了须要存储:假设对象的个数不确定.就使用集合容器进行存储. 集合容器由于内部的数据结构不同,有多种详细容器.不断的向上抽取,就形成了集合框架. ...
- JDK1.8新特性——使用新的方式遍历集合
JDK1.8新特性——使用新的方式遍历集合 摘要:本文主要学习了在JDK1.8中新增的遍历集合的方式. 遍历List 方法: default void forEach(Consumer<? su ...
- jdk1.6新特性
1.Web服务元数据 Java 里的Web服务元数据跟微软的方案基本没有语义上的区别,自从JDK5添加了元数据功能(Annotation)之后,SUN几乎重构了整个J2EE体 系, 由于变化很大,干脆 ...
- Atitit.编程语言新特性 通过类库框架模式增强 提升草案 v3 q27
Atitit.编程语言新特性 通过类库框架模式增强 提升草案 v3 q27 1. 修改历史2 2. 适用语言::几乎所有编程语言.语言提升的三个渠道::语法,类库,框架,ide2 2.1. 单根继承 ...
- JDK1.8新特性——Collector接口和Collectors工具类
JDK1.8新特性——Collector接口和Collectors工具类 摘要:本文主要学习了在Java1.8中新增的Collector接口和Collectors工具类,以及使用它们在处理集合时的改进 ...
- JDK1.8新特性——Stream API
JDK1.8新特性——Stream API 摘要:本文主要学习了JDK1.8的新特性中有关Stream API的使用. 部分内容来自以下博客: https://blog.csdn.net/icarus ...
- JDK1.8新特性(一) ----Lambda表达式、Stream API、函数式接口、方法引用
jdk1.8新特性知识点: Lambda表达式 Stream API 函数式接口 方法引用和构造器调用 接口中的默认方法和静态方法 新时间日期API default Lambda表达式 L ...
随机推荐
- Array相关的属性和方法
这里只是做了相关的列举,具体的使用方法,请参考网址. Array 对象属性 constructor 返回对创建此对象的数组函数的引用. var test=new Array(); if (test.c ...
- 安装python-ldap fatal error: lber.h: No such file or directory
sudo apt-get install libsasl2-dev python-dev libldap2-dev libssl-dev sudo apt-get install -y python- ...
- Android开发之使用Handler刷新UI控件
一.为什么必须使用Handler 线程安全问题 这个问题要理解的话很容易,如果没有这个约束,那么同时有两个线程对一个UI控件进行调整,那么控件自然就没法正常的工作,而为了解决这种二义性(就是一个东西同 ...
- having 与where 的异同点
having 与where 的异同点: where针对表中的列发挥作用,查询数据 having对查询结果中的列发挥作用,筛选数据 #查询本店商品价格比市场价低多少钱,输出低200元以上的商品 ; // ...
- requests用法
# -*- coding: cp936 -*- #xiaodeng #python 27 #requests用法 #获取http://www.weather.com.cn/data/sk/101010 ...
- oracle11g-R2静默安装报错[INS-32013]解决方案
问题描述: oracle静默安装很强大...,参数搞不对.安装就扯dan了....这个报错搞了一个下午.终于搞定了如释负重.... 如果当初选择仅仅安装oracle软件就没多事情.想一步完成(数据库软 ...
- Oracle自学笔记(一)
1.创建用户并指定表空间 create user gy_3004 identified by gy_3004 default tablespace gy_3004_data temporary tab ...
- poj 2632 Crashing Robots(模拟)
链接:poj 2632 题意:在n*m的房间有num个机器,它们的坐标和方向已知,现给定一些指令及机器k运行的次数, L代表机器方向向左旋转90°,R代表机器方向向右旋转90°,F表示前进,每次前进一 ...
- Ubuntu下,terminal经常使用快捷键
# ctrl + l - 清屏 . cLear # ctrl + c - 终止命令. # ctrl + d - 退出 shell,好像也能够表示EOF. # ctrl + r - 从命令历史中找 . ...
- 如何使用SetTimer
1.SetTimer定义在那里? SetTimer表示的是定义个定时器.根据定义指定的窗口,在指定的窗口(CWnd)中实现OnTimer事件,这样,就可以相应事件了. SetTimer有两个函数.一个 ...