java的集合框架之一
java是一套很成熟的东西,很多商用的东西都喜欢用它,用的人多,稳定。不过一般也不怎么说起它,因为太常见了,私下里说,写java应用层得就像农民工,每一处都是搭积木,根据设计师的东西如何优雅地搭好积木,当然美其名曰,论农民工搭积木的艺术修养。不难,但是东西很多,经验在里面是一个相当重要的东西。以上纯属每天扯淡,笑看即可,毕竟我目前就是个渣java程序员。
java的集合框架以collection接口当作基础,这个接口定义了基本框架,包括size、hashcode、iterator、add、addall、remove、retainall、toArray、clear等方法。也就是所有的实现了这个接口的类都必须要有这些方法。这个集合框架怎么组织的呢?collection接口定义大框架,abstractCollection作为实现了collec接口的抽象类,又实现了一些方法,但是还是没有size等方法的实现,这个叫做基础类,帮忙做一些工作,然后就是一些特定的实现类了。collection下面综合可以看又三种,set和list以及queue这三种,一般我们用list最多,set次之,queue用的最少,当然这也和我们的生活有很大关系。
list是一种有顺序允许重复的列表类数据结构,就是数据在里面是有顺序的,比如取list.get(i) 来获取一个对象,这里list不关心每个元素的值是否相同,另外list的一般的构造函数是List<String> list = new ArrayList<String>();这里用到了泛型,在编译的时候就限定了list要存取的元素。List也是一个接口,一般我们用实现类ArrayList来获取对象。list是动态增长的。另外list还可以转化为array,利用toArray方法,可以比较方便的转化为array。
Set不允许重复是一种没有顺序的集合数据结构。一般set我们见到的最多的实现类就是HashSet(客座率一般是0.75,初始容量是16,一旦超过就会翻倍),用hash来实现可以达到不错的效率。一般每个相同的对象拥有相同的hash值,这个是定义在Object方法中得,不同的对象也可能拥有相同的hash值,这个需要做一些特殊处理。set因为是用hash来实现的,所以不保证添加进set得次序,这时候可以考虑用LinkedHashSet类来处理,LinkedHashSet类当用add方法添加的时候,当打印的时候可以保证打印的顺序和当初添加的顺序是一样的,HashSet是不保证的。另外还有一个类就是TreeSet,树集,这个在上面有一些接口和抽象类做铺垫,有几个特别的方法,比如head,tail,ceil,floor等方法ceil是天花板的意思,大于等于,floor地板,于是就小于等于了。有了这些,就有点排序类的意思了,就是TreeSet类可以保证里面的元素是按照某种顺序排序。所以在TreeSet的构造函数中可以看到comparator类的参数,TreeSet也接受普通的set类,只不过两者的排序依据不太一样。说起排序原则,一般有两种,一种是自然排序,另外一种是实现了comparator接口的按照用户自己定义的某种排序方法。comparator接口,一般主要有一个compare方法需要去重写一下,然后给出返回值,参数就传含有comparator的接口对象,若返回1表示大于,返回0表示等于,返回-1表示小于。
Queue用的比较少,是一种先进先出的队列。(待续、待修改)
// 排序列表,主要是对comparator的使用
public static void sortList(List<String> list) {
Comparator<String> c = new Comparator<String>() {
@Override
public int compare(String lhs, String rhs) { int lLen = lhs.length();
int rLen = rhs.length();
int minLen = lLen > rLen ? rLen : lLen;
for (int i = ; i < minLen; i++) {
char l = lhs.charAt(i);
char r = rhs.charAt(i);
if (l - r != ) {
return r - l;
}
}
if (lLen == rLen) {
return ;
} else {
return rLen - lLen;
}
}
};
Collections.sort(list, c);
}
java的集合框架之一的更多相关文章
- java的集合框架最全详解
java的集合框架最全详解(图) 前言:数据结构对程序设计有着深远的影响,在面向过程的C语言中,数据库结构用struct来描述,而在面向对象的编程中,数据结构是用类来描述的,并且包含有对该数据结构操作 ...
- java.util 集合框架集合
java的集合框架为程序提供了一种处理对象组的标准方式.设计了一系列标准泛型接口: ⑴Collection ()接口,扩展了Iterable接口,位于集合层次结构的顶部,因此所有的集合都实现Colle ...
- Java基础——集合框架
Java的集合框架是Java中很重要的一环,Java平台提供了一个全新的集合框架.“集合框架”主要由一组用来操作对象的接口组成.不同接口描述一组不同数据类型.Java平台的完整集合框架如下图所示: 上 ...
- 浅谈Java的集合框架
浅谈Java的集合框架 一. 初识集合 重所周知,Java有四大集合框架群,Set.List.Queue和Map.四种集合的关注点不同,Set 关注事物的唯一性,List 关注事物的索引列表,Q ...
- java的集合框架set 和map的深入理解
Java的集合框架之Map的用法详解 Map有两种比较常用的实现:HashMap 和 TreeMap. HashMap: HashMap 也是无序的,也是按照哈希编码来排序的,允许使用null 值和n ...
- Java 高级-集合框架
参考资料 参考 HashMap 类似 C++ 中的 STL 标准模板库,Java 也在 java.util 包中封装了一套常用数据结构及其算法,称为集合框架.所有的集合框架都包含如下内容: 接口:代表 ...
- Java 之 集合框架(JCF)
1.集合框架 a.框架:为了实现某一目的或功能,而预先提供的一系列封装好的.具有继承或实现关系的类与集合 b.集合:①定义:Java中对一些数据结构和算法进行封装,即封装(集合也是一种对象) ②特点: ...
- 十五、Java基础---------集合框架体系以及List
在介绍集合之前先说一下数组,正如我们所知,数组是某一类型数据的集合,强调的是数据,而且必须单一:集合框架的不同之处在于存储的数据类型没有任何限制,既可以存储基本数据类型(会自动提升为相应的包装类)也可 ...
- Java的集合框架
01.为什么要使用集合框架? 解析:如果并不知道程序运行时会需要多少对象,或者需要更复杂方式存储对象,那么可以使用Java集合框架. 如果启用集合的删除方法,那么集合中所有元素的索引会自动维护. 集合 ...
随机推荐
- HDU 5937 Equation 【DFS+剪枝】 (2016年中国大学生程序设计竞赛(杭州))
Equation Time Limit: 2000/1000 MS (Java/Others) Memory Limit: 65536/32768 K (Java/Others) Total S ...
- [转]NHibernate之旅(3):探索查询之NHibernate查询语言(HQL)
本节内容 NHibernate中的查询方法 NHibernate查询语言(HQL) 1.from子句 2.select子句 3.where子句 4.order by子句 5.group by子句 实例 ...
- Windows游戏编程之从零开始d
Windows游戏编程之从零开始d I'm back~~恩,几个月不见,大家还好吗? 这段时间真的好多童鞋在博客里留言说或者发邮件说浅墨你回来继续更新博客吧. woxiangnifrr童鞋说每天都在来 ...
- 编译Hadoop源码
背景: 在阅读hadoop源代码过程中会发现部分类或者函数无法找到,这是由于Hadoop2.0使用了Protocol Buffers定义了RPC协议, 而这些Protocol Buffers文件在Ma ...
- FZU 2212 Super Mobile Charger 第六届福建省赛
题目链接:http://acm.fzu.edu.cn/problem.php?pid=2212 题目大意: 现在有n个手机,一个电量为m%(百分之m)的万能充电宝 然后输入n个手机的现有电量(百分之a ...
- Javascript 查找字符串中出现最多的字符和出现的次数
<script type="text/javascript"> //查找字符串中出现最多的字符和出现的次数 var str = 'Thatwheneying its o ...
- Oracle 11gR2 create init script
设置oracle用户变量. [oracle@db01 ~]$ vi /etc/oratab # end line: change db01:/oracle/app/product/11.2.0/db_ ...
- fopen\fread\fwrite\fscanf\fprintf\fseek\feof\rewind\fgets\fputc等系列函数使用总结
转载自:http://blog.csdn.net/xidianzhimeng/article/details/23541289 1 fopen 函数原型:FILE * fopen(const char ...
- C语言宏与单井号(#)和双井号(##)
C(和C++)中的宏(Macro)属于编译器预处理的范畴,属于编译期概念(而非运行期概念).下面对常遇到的宏的使用问题做了简单总结.关于#和##在C语言的宏中,#的功能是将其后面的宏参数进行字符串化操 ...
- Why should i use url.openStream instead of of url.getContent?
I would like to retrieve the content of a url. Similar to pythons: html_content = urllib.urlopen(&qu ...