栏目分类:
子分类:
返回
名师互学网用户登录
快速导航关闭
当前搜索
当前分类
子分类
实用工具
热门搜索
名师互学网 > IT > 软件开发 > 后端开发 > Java

2021.12.8学习记录

Java 更新时间: 发布时间: IT归档 最新发布 模块sitemap 名妆网 法律咨询 聚返吧 英语巴士网 伯小乐 网商动力

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,可以非常方便的进行文件的读写操作,以及复制、剪切、删除操作

四、集合

在集合下面,Collections接口,是一个根接口,即底层接口,所有的都继承此接口。其表示一组对象,在这一组对象里面,可以有空元素,也可以有重复元素,里面的元素可以有序,也可以无需,具体要看其具体实现类的实现方法 

在集合下面,分别有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下下面的一个是实现类

转载请注明:文章转载自 www.mshxw.com
本文地址:https://www.mshxw.com/it/644514.html
我们一直用心在做
关于我们 文章归档 网站地图 联系我们

版权所有 (c)2021-2022 MSHXW.COM

ICP备案号:晋ICP备2021003244-6号