linkList hashSet ArrayList IO 序列化 1.1.瞬态transient .字符编码表 Properties
Day12 IO 序列化
.递归_递归的概念_注意事项
1.递归:方法的递归调用--它是一种方法调用的方式--方法可以调用其本身
2.注意事项:
1).递归必须要有一个"出口(结束的条件)",否则就是死递归;
2).递归层次不能太深,否则:堆栈溢出异常
3).构造方法不能递归调用。普通方法可以递归调用,编译成功;构造方法如果递归调用,编译错误
class Student(){
public Student(){
this("刘德华");
}
public Student(String s){
this();
}
}
2.Serializable标记接口。该接口给需要序列化的类,提供了一个序列版本号。serialVersionUID. 该版本号的目的在于验证序列化的对象和对应类是否版本匹配。
1.1 3.瞬态关键字transient 什么情况下不会被序列化 被静态修饰和transient
当一个类的对象需要被序列化时,某些属性不需要被序列化,这时不需要序列化的属性可以使用关键字transient修饰。只要被transient修饰了,序列化时这个属性就不会被序列化了。
同时静态修饰也不会被序列化,因为序列化是把对象数据进行持久化存储,而静态的属于类加载时的数据,不会被序列化。
4.
Properties 类表示了一个持久的属性集。Properties 可保存在流中或从流中加载。属性列表中每个键及其对应值都是一个字符串。
特点:
1、Hashtable的子类,map集合中的方法都可以用。
2、该集合没有泛型。键值都是字符串。
3、它是一个可以持久化的属性集。键值可以存储到集合中,也可以存储到持久化的设备(硬盘、U盘、光盘)上。键值的来源也可以是持久化的设备。
4、有和流技术相结合的方法。
05.IO流_字节输出流FileOutputStream_追加写入和换行
1).追加写入:
FileOutputStream(String name,true):追加写入;
2).输出换行:
out.write("\r\n".getBytes());
5..字符编码表
1.各个国家和一些国际组织都有一些自定义的编码表,用于在计算机上显示各国的文字;
2.最早的编码表:ASCII码表(美国)
3.早期的中文码表:GB2312
4.现在:GBK(是GB2312的升级版)--一个中文占2个字节;【重点了解】
5.国际上:ISO8859-1码表(没有中文)
UTF-8 (包含中文,一个汉字3个字节) 【重点了解】
Unicode(一个字符2两个字节,包含中文)
- Big5:包含中文简体 + 繁体 (在台湾地区使用)
// 获得文件扩展名
String key = fileName.substring(fileName.lastIndexOf(".") + 1);
数据存储的常用结构有:堆栈、队列、数组、链表。我们分别来了解一下:
l 堆栈,采用该结构的集合,对元素的存取有如下的特点:
n 先进后出(即,存进去的元素,要在后它后面的元素依次取出后,才能取出该元素)。例如,子弹压进弹夹,先压进去的子弹在下面,后压进去的子弹在上面,当开枪时,先弹出上面的子弹,然后才能弹出下面的子弹。
n 栈的入口、出口的都是栈的顶端位置
n 压栈:就是存元素。即,把元素存储到栈的顶端位置,栈中已有元素依次向栈底方向移动一个位置。
n 弹栈:就是取元素。即,把栈的顶端位置元素取出,栈中已有元素依次向栈顶方向移动一个位置。
l 队列,采用该结构的集合,对元素的存取有如下的特点:
n 先进先出(即,存进去的元素,要在后它前面的元素依次取出后,才能取出该元素)。例如,安检。排成一列,每个人依次检查,只有前面的人全部检查完毕后,才能排到当前的人进行检查。
n 队列的入口、出口各占一侧。例如,下图中的左侧为入口,右侧为出口。
l 数组,采用该结构的集合,对元素的存取有如下的特点:
n 查找元素快:通过索引,可以快速访问指定位置的元素
n 增删元素慢:
u 指定索引位置增加元素:需要创建一个新数组,将指定新元素存储在指定索引位置,再把原数组元素根据索引,复制到新数组对应索引的位置。如下图
u 指定索引位置删除元素:需要创建一个新数组,把原数组元素根据索引,复制到新数组对应索引的位置,原数组中指定索引位置元素不复制到新数组中。如下图
l 链表,采用该结构的集合,对元素的存取有如下的特点:
n 多个节点之间,通过地址进行连接。例如,多个人手拉手,每个人使用自己的右手拉住下个人的左手,依次类推,这样多个人就连在一起了。
n 查找元素慢:想查找某个元素,需要通过连接的节点,依次向后查找指定元素
n 增删元素快:
u 增加元素:操作如左图,只需要修改连接下个元素的地址即可。
u 删除元素:操作如右图,只需要修改连接下个元素的地址即可。
Day08 linkList hashSet
l 数组,采用该结构的集合,对元素的存取有如下的特点:
n 查找元素快:通过索引,可以快速访问指定位置的元素
n 增删元素慢:
u 指定索引位置增加元素:需要创建一个新数组,将指定新元素存储在指定索引位置,再把原数组元素根据索引,复制到新数组对应索引的位置。如下图
u 指定索引位置删除元素:需要创建一个新数组,把原数组元素根据索引,复制到新数组对应索引的位置,原数组中指定索引位置元素不复制到新数组中。如下图
`1
ArrayList的contains方法判断元素是否重复原理
ArrayList的contains方法会使用调用方法时,传入的元素的equals方法依次与集合中的旧元素所比较,从而根据返回的布尔值判断是否有重复元素。此时,当ArrayList存放自定义类型时,由于自定义类型在未重写equals方法前,判断是否重复的依据是地址值,所以如果想根据内容判断是否为重复元素,需要重写元素的equals方法。
迭代的常规用法中我们要尽量避免在迭代过程中为集合添加/删除数据。否则会报错,原因是Java抛出了并发修改异常。
迭代过程中并发修改异常的原因为迭代器中”记忆”的集合长度与集合中实际长度不同,而导致出现索引与实际元素不符甚至无限循环的情况发生。