目录
一、File类
1.1、File类概述和构造方法
File:它是文件和目录路径名的抽象表示
文件和目录是可以通过File封装成对象的
File(String pathname) //通过将给定的路径名称字符串转换为抽象路径名来创建的新的File实例
File(String parent,String child) //从父路径名字符串和子路径名字符串创建新的File实例
File(File parent,String child) //从父抽象路径名和子路径名字符串创建新的File实例
1.2、File类创建功能
public boolean createNewFile() 当具有该名称的文件不存在时,创建一个由该抽象路径名命名的新空文件,如果文件不存在,创建文件,返回true;如果文件存在,返回false;
public boolean mkdir() 创建由此抽象路径名命名的目录
public boolean mkdirs() 创建由此抽象路径名命名的目录,包括任何必需但不存在的父目录
1.3、File类判断和获取功能
public boolean isDirectory() //测试抽象路径名表示的File是否为目录
public boolean isFile() //测试此抽象路径名表示的File是否为文件
public boolean exists() //测试此抽象路径名表示的File是否存在
public String getAbsolutePath()//返回此抽象路径名的绝对路径名字符串
public String getPath() 将此抽象路径名转换为路径名字符串
public String getName() 返回由此抽象路径名表示的文件或目录的名称
public String[] list() 返回此抽象路径名表示的目录中的文件和目录的名称字符串数组
public File[] listFiles() 返回此抽象路径名表示的目录中的文件和目录的File对象数组
1.4、File类删除功能
public boolean delete() //删除由此抽象路径名表示的文件或目录
绝对路径:完整的路径名,不需要任何其他信息就可以定位它所表示的文件
相对路径:必须使用取自其他路径名的信息进行解释
1.5、递归
递归出口:否则会出现内存溢出
递归规则:与原问题相似的规模较小的问题
案例:递归求阶乘
public static int fun(int n) {
if(n == 1)
return 1;
else
return n*fun(n-1);
}
int n = fun(5);//求5的阶乘
System.out.println(n);
案例:遍历目录
import java.io.File;
import java.io.IOException;
public class helloworld {
public static void main(String[] args) throws IOException{
//遍历目录
File file = new File("E:");
getAllFilePath(file);
}
//定义一个方法,用于获取给定目录下的所有内容
public static void getAllFilePath(File file) {
//获取给定的File目录下所有的文件或者目录的File数组
File[] filearray = file.listFiles();
//遍历该file数组,得到每一个file对象
if(filearray != null) {
for(File f : filearray) {
//判断该f对象是否是目录
if(f.isDirectory()) {
//是
getAllFilePath(f);
} else{
//不是,获取绝对路径输出再控制台
System.out.println(f.getAbsolutePath());
}
}
}
}
}
二、字节流
字节输入流;字节输出流
字符输入流;字符输出流
2.1、字节流写数据
字节流抽象基类
InputStream:这个抽象类是表示字节输入流的所有类的超类
OutputStream:这个抽象类是表示字节输出流的所有类的超类
子类名特点:子类名称都是以其父类名作为子类名的后缀
FileOutputStream(String name):创建文件输出流以指定的名称写入文件
//最后与IO相关的操作都要始放资源
void close();//关闭此文件输出流并释放与此流相关联的任何系统资源
2.2、字节流写数据的3种方式
void write(int b)//将指定的字节写入此文件输出流,一次写一个字节数据
void write(byte[] b)//将b.length字节从指定的字节数组写入此文件输出流,一次写一个字节数组数据
void write(byte[] b,int off,int len)//将len字节从指定的字节数组开始,从偏移量off开始写入此文件输出流,一次写一个字节数组的部分数据
2.3、字节流写数据的两个小问题
实现换行:不同系统实现换行的符合不同
window:\r\n
linux:\n
mac:\r
追加内容:
FileOutputStream(String name,boolean append)创建文件输出流以指定的名称写入文件;如果第二个参数为true,则字节将写入文件的末尾而不是开头
2.4、字节流写数据加异常处理
finally:在异常处理时提供finally块来执行所有清除操作
2.5、字节流读数据(一次读一个字节数据)
FileInputStream:从文件系统中的文件获取输入字节
FileInputStream(String name):通过打开与实际文件的连接来创建一个FileInputStream,该文件由文件系统中的路径名name命名
int read(); //该输入流读取一个字节的数据
需求:把文件fos.txt中的内容都读取处理在控制台输出
FileInputStream fis = new FileInputStream("fos.txt");
int by;
while((by = fis.read()) != -1) {
System.out.println((char)by);
}
2.6、字节流读数据(一次读一个字节数组数据)
FileInputStream fis = new FileInputStream("fos.txt");
byte[] by = new byte[1024];//1024及其整数倍
int len;
while((len = fis.read(by)) != -1) {
System.out.print(new String(by,0,len));
}
fis.close();
案例:复制图片
//把E:java下的123.jpg复制到 当前目录下
FileInputStream fis = new FileInputStream("E:\\java\\123.jpg");
FileOutputStream fos = new FileOutputStream("123.jpg");
byte[] by = new byte[1024];//1024及其整数倍
int len;
while((len = fis.read(by)) != -1) {
fos.write(by,0,len);
}
fis.close();
fos.close();
2.7字节缓冲流
BufferedOutputStream:该类实现缓冲输出流。通过设置这样的输出流,应用程序可以向底层输出流写入字节,而不必为写入的每个字节导致系统的调用
BufferedIntputStream:将创建一个内部缓冲区数组。当从流中读取或跳过字节时,内部缓冲区将根据需要从所包含的输入流中重新填充,一次很多字节
字节缓冲输出流:BufferedOutputStream(OutputStream out)
字节缓冲输入流:BufferedIntputStream(InputStream in)
字节缓冲流仅仅提供缓冲区,而真正的读写数据还得依靠基本的字节流对象进行操作
三、字符流
由于字节流操作中文不是特别的方便,所有java就提供字符流
字符流 = 字节流 + 编码表;
汉字在存储的时候,无论选择哪种编码存储,第一个字节都是负数
3.1、编码表
计算机中储存的信息都是用二进制数表示的;我们在屏幕上看到的英文、汉字等字符是二进制数转换之后的结果
字符集:是一个系统支持的所有字符的集合,包括各国家文字、标点符合、图形符合、数字等
Unicode字符集:为表示任意语言的任意字符而设计,是业界的一种标准。最常用的为UTF-8编码
3.2、字符串中的编码解码问题
编码:
byte[] getBytes():使用平台的默认字符集将该String编码为一系列字节,将结果存储到新的字节数组中
byte[] getBytes(String charsetName):使用指定的字符集将该String编码为一系列字节,将结果存储到新的字节数组中
解码:
String(byte[] bytes):通过使用平台的默认字符集解码指定的字符数组来构造新的String
String(byte[] bytes,String charsetName):通过指定的字符集解码指定的字节数组来构造新的String
3.3、字符流中的编码解码问题
字符流抽象基类
Reader:字符输入流的抽象类
Writer:字符输出流的抽象类
字符流中和编码解码问题相关的两个类:
InputStreamReader
OutputStreamWriter
3.4、字符流写数据的5种方式
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)//写一个字符串的一部分
void flush()//刷新流,还可以继续写数据
void close()//关闭流,释放资源,但是再关闭之前会先刷新流。一旦关闭,就不能再写数据
3.5、字符流读数据的2种方式
int read() //一次读一个字符数据
int read(char[] cbuf)//一次读一个字符数组数据
案例:复制java文件
FileReader(String fileName) //用于读取字符文件的便捷类
FileWriter(String fileName)//用于写入字符文件的便捷类
//把模块目录下的:Student.java复制到模块目录下的copy.java
InputStreamReader isr = new InputStreamReader(new FileInputStream("Student.java"),"GBK");
OutputStreamWriter osw = new OutputStreamWriter(new FileOutputStream("copy.java"),"GBK");
int ch;
while((ch = isr.read()) != -1) {
osw.write(ch);
}
isr.close();
osw.close();
改进版
//把模块目录下的:Student.java复制到模块目录下的copy.java
//根据数据源创建字符输入流对象
FileReader fr = new FileReader("Student.java");
//根据目的地创建字符输出流对象
FileWriter fw = new FileWriter("copy.java");
int ch;
while((ch = fr.read()) != -1) {
fw.write(ch);
}
fr.close();
fw.close();
3.6、字符缓冲流
BufferedWriter:将文本写入字符输出流,缓冲字符,以提供单个字符,数组和字符串的高效写入,可以指定缓冲区大小,或者可以接受默认大小。默认值足够大,可用于大多数用途
BufferedReader:从字符输入流读取文本,缓冲字符,以提供字符,数组和行的高效读取,可以指定缓冲区大小,或者可以使用默认大小。默认值足够大,可用于大多数用途
3.7、字符缓冲流特有功能
BufferedWriter:
void newLine();//写一行行分隔符,行分隔符字符串由系统属性定义
BufferedReader:
public String readLine()//读一行文字。结果包含行的内容的字符串,不包括任何行终止字符,如果流的结尾已经到达,则为null