集合

结构图:

总结:

1.集合中的元素都是对象(注意不是基本数据类型),基本数据类型要放入集合需要装箱。

2.set与list的主要区别在于set中不允许重复,而list(序列)中可以有重复对象。

3.TreeSet中可以排序,HashSet是无序的;Vector和ArrayList都是可以排序的

List

1.arrayList.add(null);后  列表中会有null

2.在list中:ArrayList和Vector都有一个缺点,就是当删除或增加集合中的某一元素时,该元素后的下标会发生变化。为解决这一缺陷,我们用LinkedList,它的元素采用独立的节点,每一个节点中存放着指向下一个节点的引用。

LinkedList的优缺点:优点 - - - 有利于方便高效的进行插入和删除操作。缺点 - - - 在进行随机元素查询时效率相对较低。

3.Vector相较于ArrayList,同步时开销较大,访问速度比ArrayList慢。

4.LinkedList中的方法只能取首位值,例如银行排队时适用该集合

5. Stack类:   表示后进先出(LIFO)的对象堆栈     Last in First out

peek()
  查看堆栈顶部的对象,但不从堆栈中移除它。

E
pop()  移除堆栈顶部的对象,并作为此函数的值返回该对象。

E
push(E item)     把项压入堆栈顶部

Ps:compator排序:

范例1:

ArrayList<Employee>
emps = new ArrayList<Employee>();

emps.add(new Employee("张三1", 21));

emps.add(new Employee("张三2", 22));

emps.add(new Employee("张三3", 23));

Collections.sort(emps, new Comparator<Employee>() {

@Override

public int compare(Employee o1, Employee o2) {

return o1.getAge() - o2.getAge();

}

});

范例2

Collections.sort(emps, new EmpCompartor());

另写一个EmpCompartor()类:

public class EmpCompartor implements
Comparator<Employee> {

@Override

public int compare(Employee o1, Employee o2) {

return o1.getAge() - o2.getAge();

}

}

Set

1.       Iterator<Integer> iterator = hashSet.iterator();

Iterator的几个方法:

hasNext()
如果仍有元素可以迭代,则返回 true

next()
返回迭代的下一个元素。

remove()
从迭代器指向的
collection 中移除迭代器返回的最后一个元素(可选操作)。

   2. comparable&   Comparator    都是用来实现集合中的排序的,只是Comparable是在集合内部定义的方法实现的排序,Comparator是在集合外部实现的排序,所以,如想实现排序,就需要在集合外定义Comparator接口的方法compare()或在集合内实现Comparable接口的方法compareTo()。 

3.排序的三种方法:

A.在需要排序的类的内部继承Comparable接口并且在下面定义一个compareTo方法(其返回值类型是int,通过不同对象的减法获值)

B.在构造一个TreeSet或list集合时,在构造器内new 一个比较器,然后在文件中创建该比较器,该比较器继承Comparator接口,并且实现该接口中的compare方法,其返回值也为int型

C. 在构造一个TreeSet或list集合时,我们使用匿名内部类,来实现Comparator接口中的compare方法,在构造时直接声明。

4.HashMap与HashTable

a.HashTable是同步的,其他的大致相同;

b.Hashtable
不允许 null (key value 都不可以),HashMap 允许 null (key 和value 都可以)。

c. 遍历方式不同,Hashtable 使用Enumeration,HashMap 使用Iterator。

d. 哈希值的使用不同,Hashtable 直接使用对象的hashCode,而HashMap 重新计算hash 值,而且用与代替求模。

Ps: 1.键必须是唯一的,一个键不能对应两个值。如果在映射表内对同一个键调用两次put 方法,第二个值就会覆盖第一个值。

2.删除元素的时候,如果直接使用remove一般无法删除干净,一边使用Iterator迭代删除

6.JAVA_SE复习(集合)的更多相关文章

  1. JAVA_SE复习(OOP2)

    面向对象编程(二) 一.static 关键字 静态属性 1.不能覆盖静态方法.要被覆盖的方法必须是非静态的.在继承链中具有相同方法名的两个静态方法是两个互相独立的类方法.调用子类的静态方法只是将父类的 ...

  2. JAVA_SE复习(OOP1)

    面向对象编程(一) 一.继承 1. 在类图表示中,使用一个分为三块的矩形表示一个类.矩形的第一块表示类名,第二块描述这个类的属性及属性的数据类型,第三块描述这个类的操作,也就是方法以及返回类型.    ...

  3. [Java复习] 集合框架 Collection

    Q1 Collection java的集合以及集合之间的继承关系? 数组和链表的区别? 固定长度,连续内存,不能扩展,随机访问快,插入删除慢.链表相反 List, Set, Map的区别? List, ...

  4. 7.JAVA_SE复习(文件)

    文件和流 1.什么是节点流和处理流 InputStream & OutputStream Reader & Writer 乃节点流, 前面加File之类的名词 的节点流 其余加动词的均 ...

  5. JAVA_SE复习(多线程)

    线程 1.两种创建线程的方式都有自身的优点.  实现 Runnable 接口的优点:  从面向对象的设计观点看,Thread 类严格来讲是一个虚拟CPU 的封装,因此只有要改变或扩展该CPU 模型 ...

  6. JAVA_SE复习(异常)

    异常.调试和断言 一. 异常的分类 1. 可查异常    例: 2. 不可查异常  例:Runtime Exception 3. 异常的分类结构: 1. 不执行finally 子句的唯一情况是虚拟机关 ...

  7. JAVA_SE复习(Class)

    一.面向对象程序设计(OOP) 1.面向对象的程序设计是程序开发的一种方法.它将对象作为程序的基本单元,将程序和 数据封装其中,以提高软件的重用性.灵活性和扩展性 2.三个特征: 封装:隐藏信息 继承 ...

  8. JAVA_SE复习(basic)

    一.数据类型 1.基本数据类型 Ps:有效标识符:_.字母.$开头  之后可有数字 整型:byte 1 short 2 int 4 long 8  (字节) 取值范围:其范围是从负2 的该数据类型位数 ...

  9. 一、Java基础--01

    Java基础测试题分析 第一题是关于基本的算法知识,这个很有必要去掌握以下,在学校也经常听老师们说找工作比试面试会出一些这方面的知识,我拿到的第一题是关于排序的,虽然很简单,但是我还是要提醒一下基础不 ...

随机推荐

  1. uva216 c++回溯法

    因为题目要求最多8台电脑,所以可以枚举全排列,然后依次计算距离进行比较,枚举量8!=40320并不大,但这种方法不如回溯法好,当数据再大一些枚举就显得笨拙了,所以这个题我用回溯法做的,回溯有一个好处是 ...

  2. [WebGL] Setting Up WebGL

    In this lesson we cover setting up WebGL for use, including creating a canvas, getting the WebGL ren ...

  3. [AngularJS] Build Your Own ng-controller Directive

    /** * Created by Answer1215 on 12/21/2014. */ angular.module('app', []) .controller('FirstCtrl' , fu ...

  4. Android基本控件之ListView(二)<ListView优化>

    之前我们说到ListView的基本用法.但是,有很多的时候会额外的占用一些内存,从而消耗了性能.既然有消耗性能的可能,那么我们就对其做出相应的优化 我们首先来说说优化的步骤: 第一步.将宽和高设置为填 ...

  5. 各种电子面单_Api接口

    电子面单是一种通过热敏纸打印输出纸质物流面单的物流服务.通过热感应显示文字,打印速度比传统针式打印速度提升4~6倍.电子面单以接口形式嵌入到自己的系统.网站上,可以在自己的平台操作打印电子面单.   ...

  6. Debian 7 升级内核

    Debian 7(wheezy)的内核是3.2,要想把内核升级到3.16怎么办呢?使用backports源! 一.添加backports源 打开/etc/apt/source.list文件,加入以下: ...

  7. Django单元测试二三事

    零.前言 之前做过一个微信公众平台的开发者后台,功能比较简单,我个人也比较懒,所以就没有写测试.前段时间更新了一下版本,对代码进行了改动.结果昨天收到消息说后台出问题了,一个功能无法使用.我检查了半天 ...

  8. PHP笔试题汇总

    1.抓取远程图片到本地,你会用什么函数? fsockopen, A 2.用最少的代码写一个求3值最大值的函数. function($a,$b,$c){* W0 z* u6 k+ e. L  a: }5 ...

  9. 关于JDK中正则表达式

    正则表达式的构造摘要 构造 匹配     字符 x 字符 x \\ 反斜线字符 \0n 带有八进制值 0 的字符 n (0 <= n <= 7) \0nn 带有八进制值 0 的字符 nn ...

  10. 集群服务器Session同步

    事实上,网站总是有状态的.每一个登录信息.用户信息常常被存储在session内部.而当一个网站被部署在不止一台服务器的时候,就会遇到session同步的问题.事实上即使一个很小的网站,也要至少有两台服 ...