6.JAVA_SE复习(集合)
集合
结构图:

总结:
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复习(集合)的更多相关文章
- JAVA_SE复习(OOP2)
面向对象编程(二) 一.static 关键字 静态属性 1.不能覆盖静态方法.要被覆盖的方法必须是非静态的.在继承链中具有相同方法名的两个静态方法是两个互相独立的类方法.调用子类的静态方法只是将父类的 ...
- JAVA_SE复习(OOP1)
面向对象编程(一) 一.继承 1. 在类图表示中,使用一个分为三块的矩形表示一个类.矩形的第一块表示类名,第二块描述这个类的属性及属性的数据类型,第三块描述这个类的操作,也就是方法以及返回类型. ...
- [Java复习] 集合框架 Collection
Q1 Collection java的集合以及集合之间的继承关系? 数组和链表的区别? 固定长度,连续内存,不能扩展,随机访问快,插入删除慢.链表相反 List, Set, Map的区别? List, ...
- 7.JAVA_SE复习(文件)
文件和流 1.什么是节点流和处理流 InputStream & OutputStream Reader & Writer 乃节点流, 前面加File之类的名词 的节点流 其余加动词的均 ...
- JAVA_SE复习(多线程)
线程 1.两种创建线程的方式都有自身的优点. 实现 Runnable 接口的优点: 从面向对象的设计观点看,Thread 类严格来讲是一个虚拟CPU 的封装,因此只有要改变或扩展该CPU 模型 ...
- JAVA_SE复习(异常)
异常.调试和断言 一. 异常的分类 1. 可查异常 例: 2. 不可查异常 例:Runtime Exception 3. 异常的分类结构: 1. 不执行finally 子句的唯一情况是虚拟机关 ...
- JAVA_SE复习(Class)
一.面向对象程序设计(OOP) 1.面向对象的程序设计是程序开发的一种方法.它将对象作为程序的基本单元,将程序和 数据封装其中,以提高软件的重用性.灵活性和扩展性 2.三个特征: 封装:隐藏信息 继承 ...
- JAVA_SE复习(basic)
一.数据类型 1.基本数据类型 Ps:有效标识符:_.字母.$开头 之后可有数字 整型:byte 1 short 2 int 4 long 8 (字节) 取值范围:其范围是从负2 的该数据类型位数 ...
- 一、Java基础--01
Java基础测试题分析 第一题是关于基本的算法知识,这个很有必要去掌握以下,在学校也经常听老师们说找工作比试面试会出一些这方面的知识,我拿到的第一题是关于排序的,虽然很简单,但是我还是要提醒一下基础不 ...
随机推荐
- Web APP 随笔
自Iphone和Android这两个牛逼的手机操作系统发布以来,在互联网界从此就多了一个新的名词-WebApp(意为基于WEB形式的应用程序,运行在高端的移动终端设备). 开发者们都知道在高端智能手机 ...
- ios开发——面试篇(一)
面试篇之内存管理与多线程 简述OC中内存管理机制.与retain配对使用的方法是dealloc还是release,为什么?需要与alloc配对使用的方法是dealloc还是release,为 ...
- iOS开发——UI篇OC篇&初始化图片方式
初始化图片方式 一.读取图片 1.从资源(resource)读取 [cpp] view plaincopyprint? UIImage* image=[UIImage imageNamed:@&q ...
- Eclipse 环境下安装PhoneGap开发插件
phoneGap开发跨所有移动平台软件已经成为未来移动终端开发的总趋势,如何在大家所熟悉的Eclipse IDE中快速安装PhoneGap开发插件,介绍如下: 点击help——>install ...
- 网络IPC:套接字之建立连接
如果处理的是面向连接的网络服务(SOCK_STREAM或SOCK_SEQPACKET),在开始交换数据以前,需要在请求服务的进程套接字(客户端)和提供服务的进程套接字(服务器)之间建立一个连接.客户端 ...
- PhpCMS标签:专题模块special标签
专题模块 专题模块PC标签调用说明 模块名:special 模块提供的可用操作 操作名 说明 lists 专题列表 content_list 专题信息列表 hits 专题信息点击排序 下面对所有的操作 ...
- 阅读uboot
下面是一个执行make XXX_config后的打印信息: pengdl@debian:~/work/costdown/new/Hi3520D_SDK_V1.0.2.2c/source/arm11/u ...
- Algernon's Noxious Emissions POJ1121 zoj1052
One of the greatest alchemists of the lower Middle Renaissance, Algernon da Vinci (one of Leonardo's ...
- css笔记12:块元素和行内元素
1.概念: 行内元素:又叫内联元素,内联元素只能容纳文本或者其他内联元素,常见的内联元素有<span><a> 块元素:块元素一般都是从新行开始,可容纳文本,其他内联元素和其他块 ...
- hadoop学习记录(四)hadoop2.6 hive配置
一.安装mysql 1安装服务器 sudo apt-get install mysql-server 2安装mysql客户端 sudo apt-get install mysql-client sud ...