java:从入门到放弃(二)

Java IO

使用File类可以进行创建或者删除文件等常用操作
createNewFile():创建新文件
delete():删除文件
exists():判断文件是否存在
File类提供两个静态常量
pathSeparator:;
separator:\
mkdir():创建文件夹
File类中定义了两个列出文件夹内容的方法
public String[] list():列出全部名称,返回一个字符串数组
public File[] listFiles():列出完整的路径,返回一个File对象数组
isDirectory():判断给定的一个路径是否是目录
IO流
字节流主要操作byte类型对象,以byte数组为准
InputStream:输入流
OutputStream:输出流
OutputStream和InputStream均是抽象类,如果要使用此类首先要通过子类实例化对象,如果要操作的是一个文件,可以使用FileOutputStream和FileInputStream类为其实例化

集合框架

为什么会出现集合类?

面向对象语言对事物的体现都是以对象的形式,为了方便对多个对象的操作,就要对对象进行存储,集合是存储对象最常用的方式。

数组和集合都是容器有何区别?

数组也可以存储对象,但长度是固定的,集合长度是可变的。数组中可以存储基本数据类型,集合只能存储对象且可以存储不同类型的对象。
集合中存储的都是对象的引用(地址)
Collecton{
List:ArrayList,LinkedList,Vector
Set:HashSet,TreeSet
}
每个容器对数据的存储方式(数据结构)都有不同。
迭代器:集合取出元素的方式
List:元素是有序的,可以重复,该集合体系有索引
迭代时,只能通过迭代器的方法操作元素
ListIterator:List集合特有的迭代器,对Iterator中的方法进行了扩充
ArrayList:底层数据结构为数组
LinkedList:底层数据结构为链表
Vector:底层数据结构为数组(出现最早,后被ArrayList取代)
Set:元素是无序的,元素不可以重复
HashSet:底层数据结构是哈希表
HashSet如何保证元素的唯一性?
通过hashCode和equals两个方法
如果元素的hashCode值相同,判断equals是否为true,如果元素的hashCode值不同,不会调用equals
TreeSet:可以对set集合中的数据进行排序
底层数据结构是二叉树
TreeSet排序的第一种方式(自然排序):让元素自身具备比较性,元素需要实现Comparable接口,覆写compareTo方法
TreeSet排序的第二种方式:当元素自身不具备比较性或者具备的比较性不是所需要的时,让集合自身具备比较性,定义比较器,将比较器对象作为参数传递给TreeSet集合的构造函数
Map
Hashtable:底层数据结构是哈希表,不可以存入null键null值,该集合是线程同步的
HashMap:底层数据结构是哈希表,允许使用null键和null值,该集合是不同步的
TreeMap:底层数据结构是二叉树,线程不同步,可以用于给map集合中的键进行排序
Map集合的两种取出方式
keySet:将map中所有键存入到Set集合,然后迭代取出所有的键,再根据get方法获取值,因为map本身不具备迭代器
entrySet:将map集合中的映射关系存到set集合,而这个关系的数据类型就是Map.Entry

你可能感兴趣的:(java)