1.File类
1.1File的介绍
File:是文件和目录路径名的抽象表示,文件和目录是可以通过File封装成对象的,对于File而言,其封装的并不是一个真正存在的文件,仅仅是一个路径名而已.它可以是存在的,也可以是不存在的.将来是要通过具体的操作把这个路径的内容转换为具体存在的
File类的构造方法
方法名 | 说明 |
---|
File(String pathname) | 通过将给定的路径名字符串转换为抽象路径名来创建新的 File实例 | File(String parent, String child) | 从父路径名字符串和子路径名字符串创建新的 File实例 | File(File parent, String child) | 从父抽象路径名和子路径名字符串创建新的 File实例 |
?1.2绝对路径和相对路径
绝对路径:是一个完整的路径,从根盘符开始
相对路径:是一个相对当前项目下的路径
1.3File类的方法
方法名 | 说明 |
---|
public boolean createNewFile() | 当具有该名称的文件不存在时,创建一个由该抽象路径名命名的新空文件 | public boolean mkdir() | 创建由此抽象路径名命名的目录 | public boolean mkdirs() | 创建由此抽象路径名命名的目录,包括任何必需但不存在的父目录 |
方法名 | 说明 |
---|
public boolean delete() | 删除由此抽象路径名表示的文件或目录 |
方法名 | 说明 |
---|
public boolean isDirectory() | 测试此抽象路径名表示的File是否为目录 | public boolean isFile() | 测试此抽象路径名表示的File是否为文件 | public boolean exists() | 测试此抽象路径名表示的File是否存在 |
方法名 | 说明 |
---|
public String getAbsolutePath() | 返回此抽象路径名的绝对路径名字符串 | public String getPath() | 将此抽象路径名转换为路径名字符串 | public String getName() | 返回由此抽象路径名表示的文件或目录的名称 | public File[] listFiles() | 返回此抽象路径名表示的目录中的文件和目录的File对象数组 |
?1.4删除一个多级文件夹
public class Test2 {
public static void main(String[] args) {
//练习二:删除一个多级文件夹
//delete方法
//只能删除文件和空文件夹.
//如果现在要删除一个有内容的文件夹?
//先删掉这个文件夹里面所有的内容.
//最后再删除这个文件夹
File src = new File("C:\\Users\\apple\\Desktop\\src");
deleteDir(src);
}
//1.定义一个方法,接收一个File对象
private static void deleteDir(File src) {
//先删掉这个文件夹里面所有的内容.
//递归 方法在方法体中自己调用自己.
//注意: 可以解决所有文件夹和递归相结合的题目
//2.遍历这个File对象,获取它下边的每个文件和文件夹对象
File[] files = src.listFiles();
//3.判断当前遍历到的File对象是文件还是文件夹
for (File file : files) {
//4.如果是文件,直接删除
if(file.isFile()){
file.delete();
}else{
//5.如果是文件夹,递归调用自己,将当前遍历到的File对象当做参数传递
deleteDir(file);//参数一定要是src文件夹里面的文件夹File对象
}
}
//6.参数传递过来的文件夹File对象已经处理完成,最后直接删除这个空文件夹
src.delete();
}
}
1.5统计文件夹下每种文件个数
public class Test3 {
public static void main(String[] args) {
//统计一个文件夹中,每种文件出现的次数.
//统计 --- 定义一个变量用来统计. ---- 弊端:同时只能统计一种文件
//利用map集合进行数据统计,键 --- 文件后缀名 值 ---- 次数
File file = new File("filemodule");
HashMap<String, Integer> hm = new HashMap<>();
getCount(hm, file);
System.out.println(hm);
}
//1.定义一个方法,参数是HashMap集合用来统计次数和File对象要统计的文件夹
private static void getCount(HashMap<String, Integer> hm, File file) {
//2.遍历File对象,获取它下边的每一个文件和文件夹对象
File[] files = file.listFiles();
for (File f : files) {
//3.判断当前File对象是文件还是文件夹
if(f.isFile()){
//如果是文件,判断这种类型文件后缀名在HashMap集合中是否出现过
String fileName = f.getName();
String[] fileNameArr = fileName.split("\\.");
if(fileNameArr.length == 2){
String fileEndName = fileNameArr[1];
if(hm.containsKey(fileEndName)){
//出现过,获取这种类型文件的后缀名出现的次数,对其+1,在存回集合中
Integer count = hm.get(fileEndName);
//这种文件又出现了一次.
count++;
//把已经出现的次数给覆盖掉.
hm.put(fileEndName,count);
}else{
// 没出现过,将这种类型文件的后缀名存入集合中,次数存1
hm.put(fileEndName,1);
}
}
}else{
//如果是文件夹,递归调用自己,HashMap集合就是参数集合,File对象是当前文件夹对象代码实现
getCount(hm,f);
}
}
}
}
2.字节流
2.1IO流介绍
IO表示输入/输出
流:是一种抽象概念,是对数据传输的总称.也就是说数据在设备间的传输称为流,流的本质是数据传输
IO流就是用来处理设备间数据传输问题的.常见的应用: 文件复制; 文件上传; 文件下载
IO流分类:
? ? ? ? 按照数据流向:输入(读数据),输出流(写数据)
? ? ? ? 按照数据类型:字节流(字节输入流,字节输出流),字符流(字符输入流,字符输出流)
IO流的使用:纯文本优先使用字符流,操作图片、视频,音乐是由字节流,在不确定的情况下是由字节流。
2.2字节流写数据和读数据
-
字节流抽象基类
-
InputStream:这个抽象类是表示字节输入流的所有类的超类 -
OutputStream:这个抽象类是表示字节输出流的所有类的超类 -
子类名特点:子类名称都是以其父类名作为子类名的后缀
2.2.1字节输出流
????????FileOutputStream(String name):创建文件输出流以指定的名称写入文件
-
使用字节输出流写数据的步骤
-
创建字节输出流对象(调用系统功能创建了文件,创建字节输出流对象,让字节输出流对象指向文件) -
调用字节输出流对象的写数据方法 -
释放资源(关闭此文件输出流并释放与此流相关联的任何系统资源)
方法名 | 说明 |
---|
void write(int b) | 将指定的字节写入此文件输出流 一次写一个字节数据 | void write(byte[] b) | 将 b.length字节从指定的字节数组写入此文件输出流 一次写一个字节数组数据 | void write(byte[] b, int off, int len) | 将 len字节从指定的字节数组开始,从偏移量off开始写入此文件输出流 一次写一个字节数组的部分数据 |
字节流写数据如何实现换行
-
windows:\r\n -
linux:\n -
mac:\r
字节流写数据如何实现追加写入
字节流写数据异常处理
? ? ? ? finally特点:被finally控制的语句一定会执行,除非JVM退出
try{
可能出现异常的代码;
}catch(异常类名 变量名){
异常的处理代码;
}finally{
执行所有清除操作;
}
2.2.2字节输入流
????????FileInputStream(String name):通过打开与实际文件的连接来创建一个FileInputStream,该文件由文件系统中的路径名name命名
-
字节输入流读取数据的步骤
-
创建字节输入流对象 -
调用字节输入流对象的读数据方法 -
释放资源
public class FileInputStreamDemo01 {
public static void main(String[] args) throws IOException {
//创建字节输入流对象
//FileInputStream(String name)
FileInputStream fis = new FileInputStream("myByteStream\\fos.txt");
int by;
while ((by=fis.read())!=-1) {
System.out.print((char)by);
}
//释放资源
fis.close();
}
}
public class FileInputStreamDemo02 {
public static void main(String[] args) throws IOException {
//创建字节输入流对象
FileInputStream fis = new FileInputStream("myByteStream\\fos.txt");
byte[] bys = new byte[1024]; //1024及其整数倍
int len;
//循环读取
while ((len=fis.read(bys))!=-1) {
System.out.print(new String(bys,0,len));
}
//释放资源
fis.close();
}
}
2.3字节缓冲流
字节缓冲流介绍
-
lBufferOutputStream:该类实现缓冲输出流.通过设置这样的输出流,应用程序可以向底层输出流写入字节,而不必为写入的每个字节导致底层系统的调用 -
lBufferedInputStream:创建BufferedInputStream将创建一个内部缓冲区数组.当从流中读取或跳过字节时,内部缓冲区将根据需要从所包含的输入流中重新填充,一次很多字节
构造方法:
方法名 | 说明 |
---|
BufferedOutputStream(OutputStream out) | 创建字节缓冲输出流对象 | BufferedInputStream(InputStream in) | 创建字节缓冲输入流对象 |
3.字符流?
3.1字符流简介
-
字符流的介绍 由于字节流操作中文不是特别的方便,所以Java就提供字符流 字符流 = 字节流 + 编码表 -
中文的字节存储方式 用字节流复制文本文件时,文本文件也会有中文,但是没有问题,原因是最终底层操作会自动进行字节拼接成中文,如何识别是中文的呢? 汉字在存储的时候,无论选择哪种编码存储,第一个字节都是负数
3.2字符串编码解码
相关方法
方法名 | 说明 |
---|
byte[] getBytes() | 使用平台的默认字符集将该 String编码为一系列字节 | byte[] getBytes(String charsetName) | 使用指定的字符集将该 String编码为一系列字节 | String(byte[] bytes) | 使用平台的默认字符集解码指定的字节数组来创建字符串 | String(byte[] bytes, String charsetName) | 通过指定的字符集解码指定的字节数组来创建字符串 |
3.3字符流写数据
-
Writer: 用于写入字符流的抽象父类 FileWriter: 用于写入字符流的常用子类
-
构造方法
方法名 | 说明 |
---|
FileWriter(File file) | 根据给定的 File 对象构造一个 FileWriter 对象 | FileWriter(File file, boolean append) | 根据给定的 File 对象构造一个 FileWriter 对象 | FileWriter(String fileName) | 根据给定的文件名构造一个 FileWriter 对象 | FileWriter(String fileName, boolean append) | 根据给定的文件名以及指示是否附加写入数据的 boolean 值来构造 FileWriter 对象 |
成员方法
方法名 | 说明 |
---|
void write(int c) | 写一个字符 | void write(char[] cbuf) | 写入一个字符数组 | void write(char[] cbuf, int off, int len) | 写入字符数组的一部分 | void write(String str) | 写一个字符串 | void write(String str, int off, int len) | 写一个字符串的一部分 |
刷新和关闭的方法
方法名 | 说明 |
---|
flush() | 刷新流,之后还可以继续写数据 | close() | 关闭流,释放资源,但是在关闭之前会先刷新流。一旦关闭,就不能再写数据 |
?3.3字符流读数据
Reader: 用于读取字符流的抽象父类
FileReader: 用于读取字符流的常用子类
构造方法
方法名 | 说明 |
---|
FileReader(File file) | 在给定从中读取数据的 File 的情况下创建一个新 FileReader | FileReader(String fileName) | 在给定从中读取数据的文件名的情况下创建一个新 FileReader |
成员方法
方法名 | 说明 |
---|
int read() | 一次读一个字符数据 | int read(char[] cbuf) | 一次读一个字符数组数据 |
public class InputStreamReaderDemo {
public static void main(String[] args) throws IOException {
FileReader fr = new FileReader("myCharStream\\b.txt");
//int read():一次读一个字符数据
// int ch;
// while ((ch=fr.read())!=-1) {
// System.out.print((char)ch);
// }
//int read(char[] cbuf):一次读一个字符数组数据
char[] chs = new char[1024];
int len;
while ((len = fr.read(chs)) != -1) {
System.out.print(new String(chs, 0, len));
}
//释放资源
fr.close();
}
}
?3.4字符缓冲流
字符缓冲流介绍
构造方法
方法名 | 说明 |
---|
BufferedWriter(Writer out) | 创建字符缓冲输出流对象 | BufferedReader(Reader in) | 创建字符缓冲输入流对象 |
?特有方法:
BufferedWriter:
方法名 | 说明 |
---|
void newLine() | 写一行行分隔符,行分隔符字符串由系统属性定义 |
BufferedReader:
方法名 | 说明 |
---|
String readLine() | 读一行文字。 结果包含行的内容的字符串,不包括任何行终止字符如果流的结尾已经到达,则为null |
4.转换流
-
InputStreamReader:是从字节流到字符流的桥梁,父类是Reader ? 它读取字节,并使用指定的编码将其解码为字符 ? 它使用的字符集可以由名称指定,也可以被明确指定,或者可以接受平台的默认字符集 -
OutputStreamWriter:是从字符流到字节流的桥梁,父类是Writer ? 是从字符流到字节流的桥梁,使用指定的编码将写入的字符编码为字节 ? 它使用的字符集可以由名称指定,也可以被明确指定,或者可以接受平台的默认字符集
构造方法
方法名 | 说明 |
---|
InputStreamReader(InputStream in) | 使用默认字符编码创建InputStreamReader对象 | InputStreamReader(InputStream in,String chatset) | 使用指定的字符编码创建InputStreamReader对象 | OutputStreamWriter(OutputStream out) | 使用默认字符编码创建OutputStreamWriter对象 | OutputStreamWriter(OutputStream out,String charset) | 使用指定的字符编码创建OutputStreamWriter对象 |
5.对象操作流?
5.1对象序列化流
对象序列化:就是将对象保存到磁盘中,或者在网络中传输对象,使用一个字节序列表示一个对象,该字节序列包含:对象的类型、对象的数据和对象中存储的属性等信息。
字节序列写到文件之后,相当于文件中持久保存了一个对象的信息
对象序列化流: ObjectOutputStream
?
public class Student implements Serializable {
private String name;
private int age;
public Student() {
}
public Student(String name, int age) {
this.name = name;
this.age = age;
}
public String getName() {
return name;
}
public void setName(String name) {
this.name = name;
}
public int getAge() {
return age;
}
public void setAge(int age) {
this.age = age;
}
@Override
public String toString() {
return "Student{" +
"name='" + name + '\'' +
", age=" + age +
'}';
}
}
public class ObjectOutputStreamDemo {
public static void main(String[] args) throws IOException {
//ObjectOutputStream(OutputStream out):创建一个写入指定的OutputStream的ObjectOutputStream
ObjectOutputStream oos = new ObjectOutputStream(new FileOutputStream("myOtherStream\\oos.txt"));
//创建对象
Student s = new Student("佟丽娅",30);
//void writeObject(Object obj):将指定的对象写入ObjectOutputStream
oos.writeObject(s);
//释放资源
oos.close();
}
}
5.2反序列化流?
public class ObjectInputStreamDemo {
public static void main(String[] args) throws IOException, ClassNotFoundException {
//ObjectInputStream(InputStream in):创建从指定的InputStream读取的ObjectInputStream
ObjectInputStream ois = new ObjectInputStream(new FileInputStream("myOtherStream\\oos.txt"));
//Object readObject():从ObjectInputStream读取一个对象
Object obj = ois.readObject();
Student s = (Student) obj;
System.out.println(s.getName() + "," + s.getAge());
ois.close();
}
}
5.3序列化的使用
?serialVersionUID:用对象序列化流序列化了一个对象后,假如我们修改了对象所属的类文件, 给对象所属的类加一个serialVersionUID。反序列化时,就会对应此值查找。
transient:一个对象中的某个成员变量的值不想被序列化, 给该成员变量加transient关键字修饰,该关键字标记的成员变量不参与序列化过程
public class Student implements Serializable{
private static final long serialVersionUID = 2L;
private String name;
private int age;
public Student() {
}
public Student(String name, int age) {
this.name = name;
this.age = age;
}
public String getName() {
return name;
}
public void setName(String name) {
this.name = name;
}
public int getAge() {
return age;
}
public void setAge(int age) {
this.age = age;
}
}
public class Demo03 {
/**
* read():
* 读取到文件末尾返回值是 -1
* readLine():
* 读取到文件的末尾返回值 null
* readObject():
* 读取到文件的末尾 直接抛出异常
* 如果要序列化的对象有多个,不建议直接将多个对象序列化到文件中,因为反序列化时容易出异常
* 建议: 将要序列化的多个对象存储到集合中,然后将集合序列化到文件中
*/
public static void main(String[] args) throws Exception {
/*// 序列化
//1.创建序列化流对象
ObjectOutputStream oos = new ObjectOutputStream(new FileOutputStream("myCode\\oos.txt"));
ArrayList<Student> arrayList = new ArrayList<>();
//2.创建多个学生对象
Student s = new Student("佟丽娅",30);
Student s01 = new Student("佟丽娅",30);
//3.将学生对象添加到集合中
arrayList.add(s);
arrayList.add(s01);
//4.将集合对象序列化到文件中
oos.writeObject(arrayList);
oos.close();*/
// 反序列化
//5.创建反序列化流对象
ObjectInputStream ois = new ObjectInputStream(new FileInputStream("myCode\\oos.txt"));
//6.将文件中的对象数据,读取到内存中
Object obj = ois.readObject();
ArrayList<Student> arrayList = (ArrayList<Student>)obj;
ois.close();
for (Student s : arrayList) {
System.out.println(s.getName() + "," + s.getAge());
}
}
}
6.Properties集合
6.1集合的使用
Properties介绍
-
是一个Map体系的集合类 -
Properties可以保存到流中或从流中加载 -
属性列表中的每个键及其对应的值都是一个字符串
public class PropertiesDemo01 {
public static void main(String[] args) {
//创建集合对象
// Properties<String,String> prop = new Properties<String,String>(); //错误
Properties prop = new Properties();
//存储元素
prop.put("it001", "佟丽娅");
prop.put("it002", "赵丽颖");
prop.put("it003", "刘诗诗");
//遍历集合
Set<Object> keySet = prop.keySet();
for (Object key : keySet) {
Object value = prop.get(key);
System.out.println(key + "," + value);
}
}
}
6.2基本方法
特有方法
方法名 | 说明 |
---|
Object setProperty(String key, String value) | 设置集合的键和值,都是String类型,底层调用 Hashtable方法 put | String getProperty(String key) | 使用此属性列表中指定的键搜索属性 | Set<String> stringPropertyNames() | 从该属性列表中返回一个不可修改的键集,其中键及其对应的值是字符串 |
?
public class PropertiesDemo02 {
public static void main(String[] args) {
//创建集合对象
Properties prop = new Properties();
//Object setProperty(String key, String value):设置集合的键和值,都是String类型
prop.setProperty("it001", "佟丽娅");
prop.setProperty("it002", "赵丽颖");
prop.setProperty("it003", "刘诗诗");
//String getProperty(String key):使用此属性列表中指定的键搜索属性
// System.out.println(prop.getProperty("itheima001"));
// System.out.println(prop.getProperty("itheima0011"));
// System.out.println(prop);
//Set<String> stringPropertyNames():从该属性列表中返回一个不可修改的键集,其中键及其对应的值是字符串
Set<String> names = prop.stringPropertyNames();
for (String key : names) {
// System.out.println(key);
String value = prop.getProperty(key);
System.out.println(key + "," + value);
}
}
}
6.3与IO流结合的方法
和IO流结合的方法
方法名 | 说明 |
---|
void load(Reader reader) | 从输入字符流读取属性列表(键和元素对) | void store(Writer writer, String comments) | 将此属性列表(键和元素对)写入此 Properties表中,以适合使用 load(Reader)方法的格式写入输出字符流 |
public class PropertiesDemo03 {
public static void main(String[] args) throws IOException {
//把集合中的数据保存到文件
// myStore();
//把文件中的数据加载到集合
myLoad();
}
private static void myLoad() throws IOException {
Properties prop = new Properties();
//void load(Reader reader):
FileReader fr = new FileReader("myOtherStream\\fw.txt");
prop.load(fr);
fr.close();
System.out.println(prop);
}
private static void myStore() throws IOException {
Properties prop = new Properties();
prop.setProperty("it001","佟丽娅");
prop.setProperty("it002","赵丽颖");
prop.setProperty("it003","刘诗诗");
//void store(Writer writer, String comments):
FileWriter fw = new FileWriter("myOtherStream\\fw.txt");
prop.store(fw,null);
fw.close();
}
}
?
---------------------------------------------------------------------------------------------------------------------------------
内容有部分存在书籍、课堂、网络记录,如有雷同纯属巧合 ?
|