一、NIO与缓冲区
NI,是new IO,在JDK1.4以后加入,目的是为了实现高速IO,减少原来IO流技术,减轻代码负担,用较少的代码代替之前的一堆代码
实现:其实质还是通过缓冲区,通过NIO对象,直在缓冲区进行操作,从而提升速度
每个数据类型(除了布尔类型),都有一个缓冲类型
CharBuffer
ByetBuffer
IntBuffer
LongtBuffer
ShortBuffer
FloatBuffer
DoubleBuffer
二、通道文件
通道,Channel 对象,类似于一个现实中的接口,连接程序与文件两端,进行操作
其实现类是一个FileChannel类,用法为:
FileChannel f = new FileInputStream()
FileChannel f = new FileOutputStream()
三、Path接口、Paths工具类与Files工具类
Path表示一个目录路径名,后面跟一个文件名,当使用Path以后,如果找到路径则返回true,否则抛出异常
Flie工具类类似于NIO,可以非常方便的进行文件的读写操作,以及复制、剪切、删除操作
四、集合
在集合下面,Collection接口,是一个根接口,即底层接口,所有的都继承此接口。其表示一组对象,在这一组对象里面,可以有空元素,也可以有重复元素,里面的元素可以有序,也可以无需,具体要看其具体实现类的实现方法
在集合下面,分别有List与Set两个接口来实现Collections接口,
五、ArrayList与Vector类
1、List list = new ArrayList()
1)实现原理:采用动态数组存储数据,在开始默认构造方法创建一个空的数组
2)第一次添加元素,数组扩充为10,之后的扩充为:原看数组大小 + 原来数组大小的一半
3)为了减少扩充次数,建议在创建数组的时候给定一个合适的大小
4)多线程安全,单线程安全,不适合进行插入和删除操作,单线程效率高
2、Vector v = new Vector()
1)实现原理:采用动态数组存储数据,在开始默认构造方法创建一个大小为10的数组
2)扩充算法:当增量为0时,增加原来的2倍,当增量大小大于0,扩充为原来大小 + 增量
3)为了减少扩充次数,建议在创建数组的时候给定一个合适的大小
4)多线程安全,单线程安全,不适合进行插入和删除操作,单线程效率低
六、LinkedList类
LinkedList的底层实现为链表,可以进行相关的插入删除操作,
注:在考虑使用接口中,应考虑以下三个问题
1)是否安全(采用Vector接口)
2)是否频繁的进行插入删除操作(采用LinkedLis接口)
3)是否先存储后遍历(采用ArrayList接口)
七、HashSet
接口Set下下面的一个是实现类