一.File类
1.file类含义:是文件和目录路径名的抽象表示,主要用于文件和目录的创建、查找和删除等操作。
2.构造方法:
①public File(String pathname) :通过将给定的路径名字符串转换为抽象路径名来创建新的 File实例。
②public File(String parent, String child) :从父路径名字符串和子路径名字符串创建新的 File实例。
③public File(File parent, String child) :从父抽象路径名和子路径名字符串创建新的 File实例。
代码如下:
// 文件路径名
String pathname = "D:\\aaa.txt";
File file1 = new File(pathname);
// 文件路径名
String pathname2 = "D:\\aaa\\bbb.txt";
File file2 = new File(pathname2);
// 通过父路径和子路径字符串
String parent = "d:\\aaa";
String child = "bbb.txt";
File file3 = new File(parent, child);
// 通过父级File对象和子路径字符串
File parentDir = new File("d:\\aaa");
String child = "bbb.txt";
File file4 = new File(parentDir, child);
tip:
1. 一个File对象代表硬盘中实际存在的一个文件或者目录。
2. 无论该路径下是否存在文件或者目录,都不影响File对象的创建。
3.常用的方法:
1.public String getAbsolutePath() :返回此File的绝对路径名字符串。
2.public String getPath() :将此File转换为路径名字符串。
3.public String getName() :返回由此File表示的文件或目录的名称。
4.public long length() :返回由此File表示的文件的长度。
4.绝对路径和相对路径的区别:
1.绝对路径:从盘符开始的路径,这是一个完整的路径。
2.相对路径:相对于项目目录的路径,这是一个便捷的路径,开发中经常使用。
5.判断功能的方法
1.public boolean exists() :此File表示的文件或目录是否实际存在。
2.public boolean isDirectory() :此File表示的是否为目录。
3.public boolean isFile() :此File表示的是否为文件。
6.创建删除功能的方法
1.public boolean createNewFile() :当且仅当具有该名称的文件尚不存在时,创建一个新的空文件。
2.public boolean delete() :删除由此File表示的文件或目录。
3.public boolean mkdir() :创建由此File表示的目录。
4.public boolean mkdirs() :创建由此File表示的目录,包括任何必需但不存在的父目录。
二.递归
含义:指在当前方法内调用自己的这种现象。
分类:
递归分为两种,直接递归和间接递归。
直接递归称为方法自身调用自己。
间接递归可以A方法调用B方法,B方法调用C方法,C方法调用A方法。
1.递归累加求和
计算1 ~ n的和:
分析:num的累和 = num + (num-1)的累和,所以可以把累和的操作定义成一个方法,递归调用。
代码:
public class DiGuiDemo {
public static void main(String[] args) {
//计算1~num的和,使用递归完成
int num = 5;
// 调用求和的方法
int sum = getSum(num);
// 输出结果
System.out.println(sum);
}
/*
通过递归算法实现.
参数列表:int
返回值类型: int
*/
public static int getSum(int num) {
/*
num为1时,方法返回1,
相当于是方法的出口,num总有是1的情况
*/
if(num == 1){
return 1;
}
/*
num不为1时,方法返回 num +(num‐1)的累和
递归调用getSum方法
*/
return num + getSum(num‐1);
}
}
图解:
2.递归求阶乘
阶乘:所有小于及等于该数的正整数的积。
如:n的阶乘:n! = n * (n‐1) *...* 3 * 2 * 1
代码:
public class DiGuiDemo {
//计算n的阶乘,使用递归完成
public static void main(String[] args) {
int n = 3;
// 调用求阶乘的方法
int value = getValue(n);
// 输出结果
System.out.println("阶乘为:"+ value);
}
/*
通过递归算法实现.
参数列表:int
返回值类型: int
*/
public static int getValue(int n) {
// 1的阶乘为1
if (n == 1) {
return 1;
}
/*
n不为1时,方法返回 n! = n*(n‐1)!
递归调用getValue方法
*/
return n * getValue(n ‐ 1);
}
}
三.字节流
IO:Java中I/O操作主要是指使用 java.io 包下的内容,进行输入、输出操作。输入也叫做读取数据,输出也叫做作写出数据。
图解:
字节:一切文件数据(文本、图片、视频等)在存储时,都是以二进制数字的形式保存,都一个一个的字节,那么传输时一样如此。所以,字节流可以传输任意文件数据。在操作流的时候,我们要时刻明确,无论使用什么样的流对象,底层传输的始终为二进制数据。
字节输出流:java.io.OutputStream 抽象类是表示字节输出流的所有类的超类,将指定的字节信息写出到目的地。它定义了字节输出流的基本共性功能方法。
使用方法:
1.public void close() :关闭此输出流并释放与此流相关联的任何系统资源。
2.public void flush() :刷新此输出流并强制任何缓冲的输出字节被写出。
3.public void write(byte[] b) :将 b.length字节从指定的字节数组写入此输出流。
4.public void write(byte[] b, int off, int len) :从指定的字节数组写入 len字节,从偏移量 off开始输
出到此输出流。
5.public abstract void write(int b) :将指定的字节输出流。
字节输入流:java.io.InputStream 抽象类是表示字节输入流的所有类的超类,可以读取字节信息到内存中。它定义了字节输入流的基本共性功能方法。
使用方法:
1.public void close() :关闭此输入流并释放与此流相关联的任何系统资源。
2.public abstract int read() : 从输入流读取数据的下一个字节。
3.public int read(byte[] b) : 从输入流中读取一些字节数,并将它们存储到字节数组 b中 。
四. 字符流
字符输入流:java.io.Reader 抽象类是表示用于读取字符流的所有类的超类,可以读取字符信息到内存中。它定义了字符输入流的基本共性功能方法。
使用方法:
1.public void close() :关闭此流并释放与此流相关联的任何系统资源。
2.public int read() : 从输入流读取一个字符。
3.public int read(char[] cbuf) : 从输入流中读取一些字符,并将它们存储到字符数组 cbuf中 。
字符输出流:java.io.Writer 抽象类是表示用于写出字符流的所有类的超类,将指定的字符信息写出到目的地。它定义了字节输出流的基本共性功能方法。
使用方法:
1.void write(int c) 写入单个字符。
2.void write(char[] cbuf) 写入字符数组。
3.abstract void write(char[] cbuf, int off, int len) 写入字符数组的某一部分,off数组的开始索引,len
写的字符个数。
4.void write(String str) 写入字符串。
5.void write(String str, int off, int len) 写入字符串的某一部分,off字符串的开始索引,len写的字符个
数。
6.void flush() 刷新该流的缓冲。
7.void close() 关闭此流,但要先刷新它。
关闭和刷新
因为内置缓冲区的原因,如果不关闭输出流,无法写出字符到文件中。但是关闭的流对象,是无法继续写出数据的。如果既想写出数据,又想继续使用流,就需要 flush 方法了。
flush :刷新缓冲区,流对象可以继续使用。
close :先刷新缓冲区,然后通知系统释放资源。流对象不可以再被使用了。
五.缓冲流
作用:比如能够高效读写的缓冲流,能够转换编码的转换流,能够持久化存储对象的序列化流等等。这些功能更为强大的流,都是在基本的流对象基础之上创建而来的,就像穿上铠甲的武士一样,相当于是对基本流对象的一种增强。
概述:
缓冲流,也叫高效流,是对4个基本的 FileXxx 流的增强,所以也是4个流,按照数据类型分类:
字节缓冲流: BufferedInputStream , BufferedOutputStream
字符缓冲流: BufferedReader , BufferedWriter
基本原理:是在创建流对象时,会创建一个内置的默认大小的缓冲区数组,通过缓冲区读写,减少系统IO
次数,从而提高读写的效率。
1. 字节缓冲流
使用方法:
1.public BufferedInputStream(InputStream in) :创建一个 新的缓冲输入流。
2.public BufferedOutputStream(OutputStream out) : 创建一个新的缓冲输出流。
代码举例:
// 创建字节缓冲输入流
BufferedInputStream bis = new BufferedInputStream(new FileInputStream("bis.txt"));
// 创建字节缓冲输出流
BufferedOutputStream bos = new BufferedOutputStream(new FileOutputStream("bos.txt"));
2. 字符缓冲流
使用方法:
1.public BufferedReader(Reader in) :创建一个 新的缓冲输入流。
2.public BufferedWriter(Writer out) : 创建一个新的缓冲输出流。
代码举例:
// 创建字符缓冲输入流
BufferedReader br = new BufferedReader(new FileReader("br.txt"));
// 创建字符缓冲输出流
BufferedWriter bw = new BufferedWriter(new FileWriter("bw.txt"));
六.转换流
字符编码和字符集:
字符编码
计算机中储存的信息都是用二进制数表示的,而我们在屏幕上看到的数字、英文、标点符号、汉字等字符是二进制数转换之后的结果。按照某种规则,将字符存储到计算机中,称为编码 。反之,将存储在计算机中的二进制数按照某种规则解析显示出来,称为解码 。比如说,按照A规则存储,同样按照A规则解析,那么就能显示正确的文本f符号。反之,按照A规则存储,再按照B规则解析,就会导致乱码现象。
字符编码: 就是一套自然语言的字符与二进制数之间的对应规则。
字符集
字符集:也叫编码表。是一个系统支持的所有字符的集合,包括各国家文字、标点符号、图形符
号、数字等。
另外,计算机要准确的存储和识别各种字符集符号,需要进行字符编码,一套字符集必然至少有一套字符编码。常见字符集有ASCII字符集、GBK字符集、Unicode字符集等。
图解如下:
还有,转换流就是字节与字符的转换: