- 缓冲流也称为高效流、或者高级流。之前学习的字节流可以称为原始流。
- 作用:缓冲流自带缓冲区、可以提高原始字节流、字符流读写数据的性能
-
缓冲流的作用?
缓冲流自带缓冲区、可以提高原始字节流、字符流读写数据的性能
-
缓冲流有几种?
- 字节缓冲流
字节缓冲输入流: BufferedInputStream
字节缓冲输出流:BufferedOutputStream
- 字符缓冲流
字符缓冲输入流:BufferedReader
字符缓冲输出流:BufferedWriter
- 字节缓冲输入流自带了8KB缓冲池,以后我们直接从缓冲池读取数据,所以性能较好。
- 字节缓冲输出流自带了8KB缓冲池,数据就直接写入到缓冲池中去,写数据性能极高了。
- 字节缓冲输入流:BufferedInputStream,提高字节输入流读取数据的性能,读写功能上并无变化。
- 字节缓冲输出流:BufferedOutputStream,提高字节输出流读取数据的性能,读写功能上并无变化。
| 构造器 | 说明 |
|---|---|
| public BufferedInputStream(InputStream is) | 可以把低级的字节输入流包装成一个高级的缓冲字节输入流管道,从而提高字节输入流读数据的性能 |
| public BufferedOutputStream(OutputStream os) | 可以把低级的字节输出流包装成一个高级的缓冲字节输出流,从而提高写数据的性能 |
package com.itheima.d1_byte_buffer;
import java.io.*;
public class ByteBufferDemo {
public static void main(String[] args) throws Exception {
try(
//1.创建一个字节输入流管道与原视频接通
InputStream is = new FileInputStream("file-io-app/src/out04.txt");
//a.把原始的字节输入流包装成高级的缓冲字节输入流
//从缓冲区里读,提高字节输入流读取数据的性能
InputStream bis=new BufferedInputStream(is);
//2.创建一个字节输出流管道与目标文件接通
OutputStream os = new FileOutputStream("file-io-app/src/out05.txt");
//b.把·字节输出流管道包装成高级的缓冲字节输出流管道
OutputStream bos=new BufferedOutputStream(os);
)
//小括号里面的可以自动释放资源
{
//3.定义一个字节数组转移数据
byte[] buffer = new byte[1024];
int len;//记录每次读取的字节数
while ((len = bis.read(buffer)) != -1) {
bos.write(buffer, 0, len);
}
System.out.println("复制完成了!");
} catch (Exception e) {
e.printStackTrace();
}
}
}
字节缓冲流的性能分析
####分别使用不同的方式复制大视频观察性能情况
需求
分别使用低级字节流和高级字节缓冲流拷贝大视频,记录耗时。
分析
使用低级的字节流按照一个一个字节的形式复制文件。
使用低级的字节流按照一个一个字节数组的形式复制文件。
使用高级的缓冲字节流按照一个一个字节的形式复制文件。
使用高级的缓冲字节流按照一个一个字节数组的形式复制文件。
建议使用字节缓冲输入流、字节缓冲输出流,结合字节数组的方式,目前来看是性能最优的组合。
package com.itheima.d2_byte_buffer_time;
import java.io.*;
public class ByteBufferTimeDemo {
public static final String SRC_FILE="D:\BaiduNetdiskDownload\day19、File、递归、IO流(一)";
public static final String DEST_FILE="D:\Temp\";
public static void main(String[] args) {
copy01();//(1)使用低级的字节流按照一个一个字节的形式复制文件。 慢的无法忍受
copy02();//(2)使用低级的字节流按照一个一个字节数组的形式复制文件。 比较慢
copy03();//(3)使用高级的缓冲字节流按照一个一个字节的形式复制文件。 很慢
copy04();//(4)使用高级的缓冲字节流按照一个一个字节数组的形式复制文件。飞快(推荐)
}
private static void copy04() {
long startTime=System.currentTimeMillis();
try(
//1.创建低级的字节输入流与源文件接通
InputStream is=new FileInputStream(SRC_FILE);
//a.把原始的字节输入流包装成高级的缓冲字节输入流
InputStream bis=new BufferedInputStream(is);
//2.创建低级的字节输出流与文件接通
OutputStream os=new FileOutputStream(DEST_FILE+"video4.avi");
//a.把原始的字节输出流包装成高级的缓冲字节输出流
OutputStream bos=new BufferedOutputStream(os);
)
//小括号里面的可以自动释放资源
{
//3.定义一个字节数组转移数据
byte[] buffer = new byte[1024];
int len;//记录每次读取的字节数
while ((len = bis.read(buffer)) != -1) {
bos.write(buffer, 0, len);
}
System.out.println("复制完成了!");
} catch (Exception e) {
e.printStackTrace();
}
long endTime=System.currentTimeMillis();
System.out.println("使用高级缓冲的字节流按照一个一个字节数组的形式复制文件耗时:"+(endTime-startTime)/1000+"s");
}
private static void copy03() {
long startTime=System.currentTimeMillis();
try (
//1.创建低级的字节输入流与源文件接通
InputStream is=new FileInputStream(SRC_FILE);
//a.把原始的字节输入流包装成高级的缓冲字节输入流
InputStream bis=new BufferedInputStream(is);
//2.创建低级的字节输出流与文件接通
OutputStream os=new FileOutputStream(DEST_FILE+"video3.avi");
//a.把原始的字节输出流包装成高级的缓冲字节输出流
OutputStream bos=new BufferedOutputStream(os);
){
//3.定义一个变量记录每次读取的字符
int b;
while((b=bis.read())!=-1){
bos.write(b);
}
}catch (Exception e){
e.printStackTrace();
}
long endTime=System.currentTimeMillis();
System.out.println("使用高级的字节流按照一个一个字节的形式复制文件耗时:"+(endTime-startTime)/1000+"s");
}
private static void copy02() {
long startTime=System.currentTimeMillis();
try(
//1.创建一个字节输入流管道与原视频接通
InputStream is = new FileInputStream(SRC_FILE);
//2.创建一个字节输出流管道与目标文件接通
OutputStream os = new FileOutputStream(DEST_FILE+"video2.avi");
)
//小括号里面的可以自动释放资源
{
//3.定义一个字节数组转移数据
byte[] buffer = new byte[1024];
int len;//记录每次读取的字节数
while ((len = is.read(buffer)) != -1) {
os.write(buffer, 0, len);
}
System.out.println("复制完成了!");
} catch (Exception e) {
e.printStackTrace();
}
long endTime=System.currentTimeMillis();
System.out.println("使用低级的字节流按照一个一个字节数组的形式复制文件耗时:"+(endTime-startTime)/1000+"s");
}
private static void copy01() {
long startTime=System.currentTimeMillis();
try (
//1.创建低级的字节输入流与源文件接通
InputStream is=new FileInputStream(SRC_FILE);
//2.创建低级的字节输出流与文件接通
OutputStream os=new FileOutputStream(DEST_FILE+"video.avi");
){
//3.定义一个变量记录每次读取的字符
int b;
while((b=is.read())!=-1){
os.write(b);
}
}catch (Exception e){
e.printStackTrace();
}
long endTime=System.currentTimeMillis();
System.out.println("使用低级的字节流按照一个一个字节的形式复制文件耗时:"+(endTime-startTime)/1000+"s");
}
}
字符缓冲流
字符缓冲输入流
- 字符缓冲输入流:BufferedReader。
- 作用:提高字符输入流读取数据的性能,除此之外多了按照行读取数据的功能。
| 构造器 | 说明 |
|---|---|
| public BufferedReader(Reader r) | 可以把低级的字符输入流包装成一个高级的缓冲字符输入流管道,从而提高字符输入流读数据的性能 |
| 方法 | 说明 |
|---|---|
| public String readLine() | 读取一行数据返回,如果读取没有完毕,无行可读返回null |
- 字符缓冲输出流:BufferedWriter。
- 作用:提高字符输出流写取数据的性能,除此之外多了换行功能
| 构造器 | 说明 |
|---|---|
| public BufferedWriter(Writer w) | 可以把低级的字符输出流包装成一个高级的缓冲字符输出流管道,从而提高字符输出流写数据的性能 |
| 方法 | 说明 |
|---|---|
| public void newLine() | 换行操作 |
package com.itheima.d3_char_buffer;
import java.io.*;
public class BufferedReaderDemo1 {
public static void main(String[] args) {
// 1、创建一个文件字符输入流与源文件接通
try (
Reader fr = new FileReader("oi-app2/src/data07.txt");
//a.把低级的字符输入流包装成高级的缓冲字符输入流
BufferedReader br=new BufferedReader(fr);
) {
// 2、用循环,每次读取一个字符数组的数据。 1024 + 1024 + 8
// char[] buffer = new char[1024]; // 1K字符
// int len;
// while ((len = br.read(buffer)) != -1) {
// String rs = new String(buffer, 0, len);
// System.out.print(rs);
// }
String line;
while((line=br.readLine())!=null){
System.out.println(line);
}
} catch(IOException e){
e.printStackTrace();
}
}
}
package com.itheima.d3_char_buffer;
import java.io.BufferedWriter;
import java.io.FileWriter;
import java.io.Writer;
public class BufferedWriterDemo2 {
public static void main(String[] args) throws Exception {
// 1、创建一个字符输出流管道与目标文件接通
// Writer fw = new FileWriter("file-io-app/src/out08.txt"); // 覆盖管道,每次启动都会清空文件之前的数据
Writer fw = new FileWriter("file-io-app/src/out08.txt", true); // 覆盖管道,每次启动都会清空文件之前的数据
BufferedWriter bw=new BufferedWriter(fw);
// a.public void write(int c):写一个字符出去
bw.write(98);
bw.write('a');
bw.write('徐'); // 不会出问题了
//bw.write("rn"); // 换行
bw.newLine();//换行
// b.public void write(String c)写一个字符串出去
bw.write("abc我是中国人");
bw.newLine();//换行
// c.public void write(char[] buffer):写一个字符数组出去
char[] chars = "abc我是中国人".toCharArray();
bw.write(chars);
bw.newLine();//换行
// d.public void write(String c ,int pos ,int len):写字符串的一部分出去
bw.write("abc我是中国人", 0, 5);
bw.newLine();//换行
// e.public void write(char[] buffer ,int pos ,int len):写字符数组的一部分出去
bw.write(chars, 3, 5);
bw.newLine();//换行
// fw.flush();// 刷新后流可以继续使用
bw.close(); // 关闭包含刷线,关闭后流不能使用
}
}
拷贝出师表到另一个文件,恢复顺序
需求:把《出师表》的文章顺序进行恢复到一个新文件中。
分析:
定义一个缓存字符输入流管道与源文件接通。
定义一个List集合存储读取的每行数据。
定义一个循环按照行读取数据,存入到List集合中去。
对List集合中的每行数据按照首字符编号升序排序。
定义一个缓存字符输出管道与目标文件接通。
遍历List集合中的每个元素,用缓冲输出管道写出并换行。
package com.itheima.d3_char_buffer;
import java.io.*;
import java.util.*;
public class BufferedCharTest3 {
public static void main(String[] args) {
//1.创建缓冲字符输入流管道与源文件接通
try(
BufferedReader br =new BufferedReader(new FileReader("oi-app2/src/csb.txt"));
//5.定义缓冲字符输出管道与目标文件接通
BufferedWriter bw=new BufferedWriter(new FileWriter("oi-app2/src/new.txt"));
) {
//2.定义一个list集合存储每行内容
List data=new ArrayList<>();
//3.定义循环,按照行读取文章
String line;
while((line=br.readLine())!=null){
data.add(line);
}
System.out.println(data);
//4.排序
//自定义排序规则
List sizes=new ArrayList<>();
Collections.addAll(sizes,"一","二","三","四","五","六","七","八","九");
Collections.sort(data, new Comparator() {
@Override
public int compare(String o1, String o2) {
//o1 八,...
//o2 七,...
return sizes.indexOf(o1.substring(0,o1.indexOf(".")))
-sizes.indexOf(o2.substring(0,o2.indexOf(".")));
}
});
System.out.println(data);
// 6、遍历集合中的每行文章写出去,且要换行
for (String datum : data) {
bw.write(datum);
bw.newLine(); // 换行
}
} catch (Exception e) {
e.printStackTrace();
}
}
}
转换流
问题引出:不同编码读取乱码问题
1、之前我们使用字符流读取中文是否有乱码?
没有的,因为代码编码和文件编码都是UTF-8。
2、如果代码编码和文件编码不一致,使用字符流直接读取还能不乱码吗?
会乱码。
文件编码和读取的编码必须一致才不会乱码。
####使用相同编码读取不同编码的文件内容
需求:分别使用如下两种方式读取文件内容
代码编码是UTF-8,文件编码也是UTF-8,使用字符流读取观察输出的中文字符结果。
代码编码是UTF-8,文件编码使用GBK,使用字符流读取观察输出的中文字符结果.
字符流直接读取文本内容?
- 必须文件和代码编码一致才不会乱码
- 如果文件和代码编码不一致,读取将出现乱码。
package com.itheima.d4_transfer_stream;
import java.io.BufferedReader;
import java.io.FileReader;
import java.io.IOException;
import java.io.Reader;
public class CharSetTest00 {
public static void main(String[] args) {
try(
// //代码和文件都是UTF-8 不会乱码
// Reader fr = new FileReader("oi-app2/src/data07.txt");
//代码UTF-8 文件GDK 乱码
Reader fr = new FileReader("D:\Temp\abc我爱你中国.txt");
//a.把低级的字符输入流包装成高级的缓冲字符输入流
BufferedReader br=new BufferedReader(fr);
) {
String line;
while((line=br.readLine())!=null){
System.out.println(line);
}
} catch(
IOException e){
e.printStackTrace();
}
}
}
字符输入转换流
1、如果代码编码和文件编码不一致,使用字符流直接读取还能不乱码吗?
会乱码。
2、如果如何解决呢?
- 使用字符输入转换流
- 可以提取文件(GBK)的原始字节流,原始字节不会存在问题。
- 然后把字节流以指定编码转换成字符输入流,这样字符输入流中的字符就不乱码了
- 字符输入转换流:InputStreamReader,可以把原始的字节流按照指定编码转换成字符输入流
| 构造器 | 说明 |
|---|---|
| public InputStreamReader(InputStream is) | 可以把原始的字节流按照代码默认编码转换成字符输入流。几乎不用,与默认的FileReader一样。 |
| public InputStreamReader(InputStream is ,String charset) | 可以把原始的字节流按照指定编码转换成字符输入流,这样字符流中的字符就不乱码了(重点) |
package com.itheima.d4_transfer_stream;
import java.io.*;
public class InputStreamReaderDemo01 {
public static void main(String[] args) throws Exception {
// 代码UTF-8 文件 GBK ""D:\Temp\abc我爱你中国.txt""
//1.提取GBK文件的原始字节流。abc 我
// 000 00
InputStream is=new FileInputStream("D:\Temp\abc我爱你中国.txt");
//2.把原始字节流转成字符输入流
//默认以UTF-8的方式转成字符流,还是会乱码的,跟直接写FileReader一样
//Reader isr=new InputStreamReader(is);
//以指定的GBK编码转换成字符输入流,不会乱码。完美解决乱码问题
Reader isr=new InputStreamReader(is,"GBK");
//包装成缓冲流
BufferedReader br=new BufferedReader(isr);
//以行读取
String line;
while((line=br.readLine())!=null){
System.out.println(line);
}
}
}
字符输入转换流InputStreamReader作用:
- 可以解决字符流读取不同编码乱码的问题
- public InputStreamReader(InputStream is,String charset):
- 可以指定编码把原始字节流转换成字符流,如此字符流中的字符不乱码。
1、如果需要控制写出去的字符使用的编码,怎么办?
可以把字符以指定编码获取字节后再使用字节输出流写出去:
“我爱你中国”.getBytes(编码)
也可以使用字符输出转换流实现。
- 字符输入转换流:OutputStreamWriter,可以把字节输出流按照指定编码转换成字符输出流。
| 构造器 | 说明 |
|---|---|
| public OutputStreamWriter(OutputStream os) | 可以把原始的字节输出流按照代码默认编码转换成字符输出流。几乎不用。 |
| public OutputStreamWriter(OutputStream os,String charset) | 可以把原始的字节输出流按照指定编码转换成字符输出流(重点) |
package com.itheima.d4_transfer_stream;
import java.io.*;
import java.nio.Buffer;
public class OutputStreamWriterDemo02 {
public static void main(String[] args) throws Exception {
// 1、定义一个字节输出流
OutputStream os = new FileOutputStream("oi-app2/src/out03.txt");
//2.把原始的字节输出流转换成字符输出流
//以默认的UTF-8写字符出去,跟直接写FileWriter一样
//Writer osw=new OutputStreamWriter(os);
//指定GBK方式写字符出去
Writer osw=new OutputStreamWriter(os,"GBK");
//3.把低级的字符输出流包装成高级的缓冲字符输出流
BufferedWriter bw=new BufferedWriter(osw);
bw.write("我爱中国1");
bw.write("我爱中国2~~");
bw.write("我爱中国3");
bw.close();
}
}
字符输出转换流OutputStreamWriter的作用?
- public OutputStreamWriter(OutputStream os,String charset)
- 可以指定编码把字节输出流转换成字符输出流,从而可以指定写出去的字符编码!
- 作用:以内存为基准,把内存中的对象存储到磁盘文件中去,称为对象序列化。
- 使用到的流是对象字节输出流:ObjectOutputStream
- 使用到的流是对象字节输出流:ObjectOutputStream
| 构造器 | 说明 |
|---|---|
| public ObjectOutputStream(OutputStream out) | 把低级字节输出流包装成高级的对象字节输出流 |
| 方法名称 | 说明 |
|---|---|
| public final void writeObject(Object obj) | 把对象写出去到对象序列化流的文件中去 |
- 对象序列化的含义是什么?
把对象数据存入到文件中去。 - 对象序列化用到了哪个流?
对象字节输出流ObjectOutputStram
public void writeObject(Object obj) - 序列化对象的要求是怎么样的?
对象必须实现序列化接口
package com.itheima.d5_serializable;
import java.io.Serializable;
public class Student implements Serializable {
//申明序列化的版本号码
//序列化的版本号与反序列化的版本号必须一致才不会出错
private static final long serialVersionUID=1;
private String name;
private String loginName;
//transient修饰的成员变量不参与序列化了
private transient String passWord;
private int age;
public Student() {
}
public Student(String name, String loginName, String passWord, int age) {
this.name = name;
this.loginName = loginName;
this.passWord = passWord;
this.age = age;
}
public String getName() {
return name;
}
public void setName(String name) {
this.name = name;
}
public String getLoginName() {
return loginName;
}
public void setLoginName(String loginName) {
this.loginName = loginName;
}
public String getPassWord() {
return passWord;
}
public void setPassWord(String passWord) {
this.passWord = passWord;
}
public int getAge() {
return age;
}
public void setAge(int age) {
this.age = age;
}
@Override
public String toString() {
return "Student{" +
"name='" + name + ''' +
", loginName='" + loginName + ''' +
", passWord='" + passWord + ''' +
", age=" + age +
'}';
}
}
package com.itheima.d5_serializable;
import java.io.FileNotFoundException;
import java.io.FileOutputStream;
import java.io.ObjectOutputStream;
public class ObjectOutPutStreamDemo1 {
public static void main(String[] args) throws Exception {
//1.创建学生对象
Student s=new Student("陈磊","陈磊","1314520",21);
//2.对象序列化,使用对象字节输出流包装字节输出流管道
ObjectOutputStream oos=new ObjectOutputStream(new FileOutputStream("oi-app2/src/obj.txt"));
//3.直接调用序列化方法
oos.writeObject(s);
//4.释放资源
oos.close();
}
}
###对象反序列化
对象反序列化:- 使用到的流是对象字节输入流:ObjectInputStream
- 作用:以内存为基准,把存储到磁盘文件中去的对象数据恢复成内存中的对象,称为对象反序列化。
####对象反序列化:
- 使用到的流是对象字节输入流:ObjectInputStream
- 作用:以内存为基准,把存储到磁盘文件中去的对象数据恢复成内存中的对象,称为对象反序列化。
| 构造器 | 说明 |
|---|---|
| public ObjectInputStream(InputStream out) | 把低级字节输如流包装成高级的对象字节输入流 |
| 方法名称 | 说明 |
|---|---|
| public Object readObject() | 把存储到磁盘文件中去的对象数据恢复成内存中的对象返回 |
package com.itheima.d5_serializable;
import java.io.FileInputStream;
import java.io.FileNotFoundException;
import java.io.ObjectInputStream;
public class ObjectInputStreamDemo2 {
public static void main(String[] args) throws Exception {
//1.创建对象字节输入流管道包装成低级的字节输入流管道
ObjectInputStream ois=new ObjectInputStream(new FileInputStream("oi-app2/src/obj.txt"));
//2.调用对象字节输入流的反序列方法
Student s= (Student) ois.readObject();
System.out.println(s);
}
}
- 对象反序列化的含义是什么?
把磁盘中的对象数据恢复到内存的Java对象中。 - 对象反序列化用到了哪个流?
对象字节输入流ObjectInputStram
public Object readObject()
- 作用:打印流可以实现方便、高效的打印数据到文件中去。打印流一般是指:PrintStream,PrintWriter两个类。
- 可以实现打印什么数据就是什么数据,例如打印整数97写出去就是97,打印boolean的true,写出去就是true。
####PrintStream(继承字节输出流)
| 构造器 | 说明 |
|---|---|
| public PrintStream(OutputStream os) | 打印流直接通向字节输出流管道 |
| public PrintStream(File f) | 打印流直接通向文件对象 |
| public PrintStream(String filepath) | 打印流直接通向文件路径 |
| 方法 | 说明 |
|---|---|
| public void print(Xxx xx) | 打印任意类型的数据出去 |
| 构造器 | 说明 |
|---|---|
| public PrintWriter(OutputStream os) | 打印流直接通向字节输出流管道 |
| public PrintWriter (Writer w) | 打印流直接通向字符输出流管道 |
| public PrintWriter (File f) | 打印流直接通向文件对象 |
| public PrintWriter (String filepath) | 打印流直接通向文件路径 |
| 方法 | 说明 |
|---|---|
| public void print(Xxx xx) | 打印任意类型的数据出去 |
####PrintStream和PrintWriter的区别
打印数据功能上是一模一样的,都是使用方便,性能高效(核心优势)
PrintStream继承自字节输出流OutputStream,支持写字节数据的方法。
PrintWriter继承自字符输出流Writer,支持写字符数据出去。
package com.itheima.d6_printStream;
import java.io.FileNotFoundException;
import java.io.FileOutputStream;
import java.io.PrintStream;
import java.io.PrintWriter;
public class PrintDemo1 {
public static void main(String[] args) throws Exception {
//1.创建一个打印流对象
//PrintStream ps=new PrintStream(new FileOutputStream("oi-app2/src/ps.txt"));
PrintStream ps=new PrintStream("oi-app2/src/ps.txt");
//打印功能上与PrintStream的使用没有区别
PrintWriter pw=new PrintWriter("oi-app2/src/ps.txt");
ps.println(97);
ps.println('a');
ps.println(true);
ps.println("我是啥就打印啥");
pw.write("我在学习字符流");
ps.close();
}
}
- 打印流有几种?各有什么特点?
打印流一般是指:PrintStream,PrintWriter两个类。
打印功能2者是一样的使用方式
PrintStream继承自字节输出流OutputStream,支持写字节
PrintWrite继承自字符输出流Writer,支持写字符 - 打印流的优势是什么?
两者在打印功能上都是使用方便,性能高效(核心优势)
属于打印流的一种应用,可以把输出语句的打印位置改到文件。
package com.itheima.d6_printStream;
import java.io.PrintStream;
import java.io.PrintWriter;
public class PrintDemo2 {
public static void main(String[] args) throws Exception {
System.out.println("锦瑟无端五十弦");
System.out.println("一弦一柱思华年");
//改变输出语句的位置(重定向)
PrintStream ps=new PrintStream("oi-app2/src/log.txt");
System.setOut(ps);//把系统打印流改成自己的打印流
System.out.println("庄生晓梦迷蝴蝶");
System.out.println("望帝春心托杜鹃");
}
}
补充知识:Properties
####Properties属性集对象
其实就是一个Map集合,但是我们一般不会当集合使用,因为HashMap更好用。
Properties核心作用:- Properties代表的是一个属性文件,可以把自己对象中的键值对信息存入到一个属性文件中去。
- 属性文件:后缀是.properties结尾的文件,里面的内容都是 key=value,后续做系统配置信息的。
Properties和IO流结合的方法:
| 构造器 | 说明 |
|---|---|
| void load(InputStream inStream) | 从输入字节流读取属性列表(键和元素对) |
| void load(Reader reader) | 从输入字符流读取属性列表(键和元素对) |
| void store(OutputStream out, String comments) | 将此属性列表(键和元素对)写入此 Properties表中,以适合于使用 load(InputStream)方法的格式写入输出字节流 |
| void store(Writer writer, String comments) | 将此属性列表(键和元素对)写入此 Properties表中,以适合使用 load(Reader)方法的格式写入输出字符流 |
| public Object setProperty(String key, String value) | 保存键值对**(put)** |
| public String getProperty(String key) | 使用此属性列表中指定的键搜索属性值 (get) |
| public Set stringPropertyNames() | 所有键的名称的集合 (keySet()) |
package com.itheima.d7_properties;
import java.io.FileWriter;
import java.util.Properties;
public class PropertiesDemo1 {
public static void main(String[] args) throws Exception{
//需求:使用Properties把键值对信息存入到属性文件中去
Properties properties=new Properties();
properties.setProperty("admin","123456");
properties.setProperty("dlei","008795");
properties.setProperty("heima","itcast");
System.out.println(properties);
properties.store(new FileWriter("oi-app2/src/users.properties"),
"give me 100");
}
}
package com.itheima.d7_properties;
import java.io.FileReader;
import java.util.Properties;
import java.util.Set;
public class PropertiesDemo02 {
public static void main(String[] args) throws Exception {
// 需求:Properties读取属性文件中的键值对信息。(读取)
Properties properties = new Properties();
System.out.println(properties);
//记载属性文件中的键值对数据到属性对象properties中去
properties.load(new FileReader("oi-app2/src/users.properties"));
System.out.println(properties);
String rs= properties.getProperty("dlei");
System.out.println(rs);
String rs1= properties.getProperty("admin");
System.out.println(rs1);
}
}
- Properties的作用?
可以存储Properties属性集的键值对数据到属性文件中去:
void store(Writer writer, String comments)
可以加载属性文件中的数据到Properties对象中来:
void load(Reader reader)
####commons-io概述
-
commons-io是apache开源基金组织提供的一组有关IO操作的类库,可以提高IO功能开发的效率。
-
commons-io工具包提供了很多有关io操作的类。有两个主要的类FileUtils, IOUtils
####FileUtils主要有如下方法:
| 方法名 | 说明 |
|---|---|
| String readFileToString(File file, String encoding) | 读取文件中的数据, 返回字符串 |
| void copyFile(File srcFile, File destFile) | 复制文件。 |
| void copyDirectoryToDirectory(File srcDir, File destDir) | 复制文件夹。 |
####导入commons-io-2.6.jar做开发
需求
使用commons-io简化io流读写
分析
在项目中创建一个文件夹:lib
将commons-io-2.6.jar文件复制到lib文件夹
在jar文件上点右键,选择 Add as Library -> 点击OK
在类中导包使用
package com.itheima.d8_commons_io;
import org.apache.commons.io.FileUtils;
import org.apache.commons.io.IOUtils;
import java.io.File;
import java.io.FileInputStream;
import java.io.FileOutputStream;
public class CommonsIODemo01 {
public static void main(String[] args) throws Exception {
// 1.完成文件复制!
// IOUtils.copy(new FileInputStream("C:\Users\zhao\Pictures\微信图片_20220429140831.jpg"),new FileOutputStream("D:\Temp\new.jpg"));
// 2.完成文件复制到某个文件夹下!
FileUtils.copyFileToDirectory(new File("C:\Users\zhao\Pictures\微信图片_20220429140831.jpg"),new File("D:/"));
//3.完成文件夹复制到文件夹
FileUtils.copyDirectoryToDirectory(new File("D:/Temp/aaa"), new File("D:/Temp/ccc"));
//删掉
FileUtils.deleteDirectory(new File("D:/Temp/ccc/aaa"));
}
}
| org.apache.commons.io.input | 输入流相关的实现类,包含Reader和InputStream |
| org.apache.commons.io.output | 输出流相关的实现类,包含Writer和OutputStream |
| org.apache.commons.io.serialization | 序列化相关的类
步骤:
1. 下载commons-io相关jar包;http://commons.apache.org/proper/commons-io/
2. 把commons-io-2.6.jar包复制到指定的Module的lib目录中
3. 将commons-io-2.6.jar加入到classpath中
小结:
IOUtils和FileUtils可以方便的复制文件和文件夹!!
*/
public class CommonsIODemo01 {
public static void main(String[] args) throws Exception {
// 1.完成文件复制!
// IOUtils.copy(new FileInputStream(“C:UserszhaoPictures微信图片_20220429140831.jpg”),new FileOutputStream(“D:Tempnew.jpg”));
// 2.完成文件复制到某个文件夹下!
FileUtils.copyFileToDirectory(new File("C:\Users\zhao\Pictures\微信图片_20220429140831.jpg"),new File("D:/"));
//3.完成文件夹复制到文件夹
FileUtils.copyDirectoryToDirectory(new File("D:/Temp/aaa"), new File("D:/Temp/ccc"));
//删掉
FileUtils.deleteDirectory(new File("D:/Temp/ccc/aaa"));
}
}



