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的集合框架之一的更多相关文章

  1. java的集合框架最全详解

    java的集合框架最全详解(图) 前言:数据结构对程序设计有着深远的影响,在面向过程的C语言中,数据库结构用struct来描述,而在面向对象的编程中,数据结构是用类来描述的,并且包含有对该数据结构操作 ...

  2. java.util 集合框架集合

    java的集合框架为程序提供了一种处理对象组的标准方式.设计了一系列标准泛型接口: ⑴Collection ()接口,扩展了Iterable接口,位于集合层次结构的顶部,因此所有的集合都实现Colle ...

  3. Java基础——集合框架

    Java的集合框架是Java中很重要的一环,Java平台提供了一个全新的集合框架.“集合框架”主要由一组用来操作对象的接口组成.不同接口描述一组不同数据类型.Java平台的完整集合框架如下图所示: 上 ...

  4. 浅谈Java的集合框架

    浅谈Java的集合框架 一.    初识集合 重所周知,Java有四大集合框架群,Set.List.Queue和Map.四种集合的关注点不同,Set 关注事物的唯一性,List 关注事物的索引列表,Q ...

  5. java的集合框架set 和map的深入理解

    Java的集合框架之Map的用法详解 Map有两种比较常用的实现:HashMap 和 TreeMap. HashMap: HashMap 也是无序的,也是按照哈希编码来排序的,允许使用null 值和n ...

  6. Java 高级-集合框架

    参考资料 参考 HashMap 类似 C++ 中的 STL 标准模板库,Java 也在 java.util 包中封装了一套常用数据结构及其算法,称为集合框架.所有的集合框架都包含如下内容: 接口:代表 ...

  7. Java 之 集合框架(JCF)

    1.集合框架 a.框架:为了实现某一目的或功能,而预先提供的一系列封装好的.具有继承或实现关系的类与集合 b.集合:①定义:Java中对一些数据结构和算法进行封装,即封装(集合也是一种对象) ②特点: ...

  8. 十五、Java基础---------集合框架体系以及List

    在介绍集合之前先说一下数组,正如我们所知,数组是某一类型数据的集合,强调的是数据,而且必须单一:集合框架的不同之处在于存储的数据类型没有任何限制,既可以存储基本数据类型(会自动提升为相应的包装类)也可 ...

  9. Java的集合框架

    01.为什么要使用集合框架? 解析:如果并不知道程序运行时会需要多少对象,或者需要更复杂方式存储对象,那么可以使用Java集合框架. 如果启用集合的删除方法,那么集合中所有元素的索引会自动维护. 集合 ...

随机推荐

  1. BZOJ_1003_[ZJOI2006]_物流运输_(动态规划+最短路)

    描述 http://www.lydsy.com/JudgeOnline/problem.php?id=1003 m个码头,从1运货到m,n天每天运,其中有一些码头在特定的天里不能使用.运货的代价:在两 ...

  2. Android-RC4的加密解密代码

    static String RC4(String keys, String encrypt) { char[] keyBytes = new char[256]; char[] cypherBytes ...

  3. ARM学习笔记5——程序状态寄存器

    当前程序状态寄存器CPSR可以在任何位处理器模式下被访问,它包含条件码标志.中断控制.当前处理器模式以及其他状态和控制信息.CPSR的结构图如下: 一.条件标志位 CPSR最高4位:N(Negativ ...

  4. HDOJ/HDU Tempter of the Bone(深搜+奇偶性剪枝)

    Problem Description The doggie found a bone in an ancient maze, which fascinated him a lot. However, ...

  5. vss搭建于操作

    1.下载的vvs2005,下载后先安装在服务器上,反正就是下一步下一步就对了 安装完成后,打开miscrosoft visual sourcesafe,---create  connection da ...

  6. 虚拟机之仅主机模式(HostOnly)链接外网设置

    我的环境: 虚拟机-VMware 虚拟系统-CentOS 现实主机-win7 具体设置步骤: 一.设置现实主机 (地址等不用额外设置,下面是我电脑正常上网的配置) 将本地链接设置共享(这步很重要) 二 ...

  7. hadoop家族之mahout安装

    步骤一.下载mahout  http://www.apache.org/dyn/closer.cgi/mahout/ 我下载的是 mahout-distribution-0.9.tar.gz 16-F ...

  8. c 语言结构体struct的三种定义方式 及 typedef

    struct 结构体名{ 成员列表: ..... }结构体变量: 结构体类型变量的定义 结构体类型变量的定义与其它类型的变量的定义是一样的,但由于结构体类型需要针对问题事先自行定义,所以结构体类型变量 ...

  9. Java从服务器上获取时间,动态在jsp页面显示

    Java获取服务器时间,动态显示到jsp页面,大家都是到Java只能获取一次,到页面的时间是静态的,不过通过js和Java的合作,巧妙地实现此功能 本人是给电视做系统,客户要求页面能显示时间,因为电视 ...

  10. UIApplication和delegate