2021.12.8学习记录

一、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下下面的一个是实现类

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值