一、File类
示例一:
import java.io.File;
import java.io.IOException;
/*
* File类常见方法
* 1.创建
* boolean createNewFile() //在指定的目录下创建文件, 如果这个文件存在, 则不会创建(返回false)
* 和输出流不一样, 输出流对象一建立, 就会创建, 而且会覆盖已经有的文件
* boolean mkdir() //在指定目录下创建文件夹, 如果这个文件夹存在则不会创建(返回false)
* boolean mkdirs() //创建多级文件夹
*
* 2.删除
* boolean delete() //删除文件或者文件夹, 删除失败则返回false
* void deleteOnExit() //交由JVM在程序结束的时候把文件删除
*
* 3.判断
* boolean exists() //文件是否存在
* boolean isDirectory() //判断是否是目录
* boolean isFile() //判断是否是文件
* boolean isHidden() //判断是否是隐藏文件
* boolean isAbsolute() //判断是否是绝对路径, "D:/a/a/a.txt",
* //是则返回true, 否则false, 即使文件不存在也可以判断, 只要封装到File对象中了
*
* 4.获取
* String getAbsolutePath() //获取文件的决定路径
* String getPath() //获取文件的路径(封装的什么路径就获取到什么路径)
* String getName() //获取文件的名字
* String getParent() //返回绝对路径中的文件父目录, 如果获取的是相对路径则返回null, 如:"a.txt", 则会返回null
* //如果该相对目录中有上层目录, 则返回上层目录, 如: "b/a.txt", 则返回b
* long lastModified() //返回文件最后一次修改的时间
* boolean renameTo() //重命名(把以前的文件删除, 并建立新的文件, 把原文件的类容拷贝到新的文件下)
*
*
*/
public class FileDemo {
public static void main(String[] args) throws IOException {
fileMethod4();
}
public static void cos() {
// 将d.txt封装成对象
File file = new File("d.txt");
File file2 = new File("D:/", "a.txt");
File d = new File("D:/");
File file3 = new File(d, "e.txt");
// separator跨平台的目录分隔符
File file4 = new File("D:" + File.separator + "d.txt");
System.out.println(file);
System.out.println(file2);
System.out.println(file3);
System.out.println(file4);
}
public static void fileMethod() throws IOException {
File file = new File("D:" + File.separator + "file.txt");
System.out.println("create : " + file.createNewFile());
boolean b = file.delete(); //删除文件
//判断文件是否存在
System.out.println("exists : " + file.exists());
File file2 = new File("D:" + File.separator + "a");
System.out.println("mkdir : " + file2.mkdir());
File file3 = new File("D:" + File.separator + "a" + File.separator + "b");
System.out.println("mkdirs : " + file3.mkdirs());
}
public static void fileMethod2(){
//判断文件对象是否是目录或者文件时, 一定要先判断该文件或者目录是否存在
//用exists()方法进行判断是否存在
File file = new File("D:" + File.separator + "fos.txt");
boolean b = file.isFile();
boolean d = file.isDirectory();
System.out.println("isFile : " + b);
System.out.println("isDirectory : " + d);
boolean p = file.isAbsolute(); //判断是否是绝对路径
}
public static void fileMethod3(){
File file = new File("D:/3.txt");
//获取文件的决定路径
String path = file.getAbsolutePath();
//获取文件的路径(封装的什么路径就获取什么路径)
String path2 = file.getPath();
//获取文件的名字
String name = file.getName();
//返回绝对路径中的文件父目录
String path3 = file.getParent();
//返回文件最后一次修改的时间
long lastTime = file.lastModified();
//返回文件的大小
long size = file.length();
System.out.println("getAbsolutePath : " + path);
System.out.println("getPath : " + path2);
System.out.println("name : " + name);
System.out.println("getParent : "+ path3);
System.out.println("lastModified : " + lastTime);
System.out.println("length : "+ size);
}
public static void fileMethod4(){
File file = new File("D:/q.txt");
File newFile = new File("D:/1.txt");
//重命名文件(把以前的文件删除, 并拷贝到新的文件下)
boolean b = file.renameTo(newFile);
System.out.println(b);
}
}
示例二:
public static void listDemo(){
File file = new File("C:/");
//返回指定文件夹下所有文件和文件夹(包含隐藏文件)
//调用list()方法的File对象必须是封装了一个目录, 该目录必须存在
String[] strings = file.list();
for (String string : strings) {
System.out.println(string);
}
}
public static void acceptFile(){
File dir = new File("D:/");
//文件名过滤
String[] files = dir.list(new FilenameFilter() {
@Override
public boolean accept(File dir, String name) {
return name.endsWith(".mp3");
}
});
for (String string : files) {
System.out.println(string);
}
}
示例三:
import java.io.File;
//列出指定目录下所有的文件和文件夹, 包含子目录
//因为目录中还有目录, 只要使用同一个列出目录的函数即可.
//在列出过程中还有目录的话, 还可以使用该函数
//也就是函数自己调用自己, 这样的表现形式, 称为递归.
//递归需要注意的是:
//1.限定条件(出口)
//2.递归次数, 避免内存溢出
public class FileDemo3 {
public static void main(String[] args) {
showDir(new File("D:/"));
}
public static void showDir(File dir) {
System.out.println(dir);
File[] files = dir.listFiles();
for (int i = 0; i < files.length; i++) {
//隐藏文件不让访问, 不判断则会报异常, 程序终止
if (files[i].isDirectory() && !files[i].isHidden())
showDir(files[i]);
else
System.out.println(files[i]);
}
}
}
二、ObjectOutputStream和ObjectInputStream
示例:
//序列化
//静态的, 不能被序列化
import java.io.FileInputStream;
import java.io.FileOutputStream;
import java.io.IOException;
import java.io.ObjectInputStream;
import java.io.ObjectOutputStream;
import java.io.Serializable;
public class ObjectStreamDemo01 {
public static void main(String[] args) throws Exception {
readObj();
}
public static void writeObj() throws IOException{
ObjectOutputStream oos = new ObjectOutputStream(new FileOutputStream("D:/p.txt"));
oos.writeObject(new Person("tom", 2222));
oos.flush();
oos.close();
}
public static void readObj() throws Exception{
ObjectInputStream ois = new ObjectInputStream(new FileInputStream("D:/p.txt"));
Person p = (Person)ois.readObject();
ois.close();
System.out.println(p);
}
}
//Serializable标识该类要被序列化, 该Serializable接口中没有任何方法
@SuppressWarnings("serial")
class Person implements Serializable{
private String name;
//transient关键字, 表示不能被序列化
private transient int age;
//静态不能被序列化
private static String cn;
public Person(String name, int age) {
this.age = age;
this.name = name;
}
public String toString(){
return name + " : " + age;
}
}
三、PipedInputStream和PipedOutputStream
示例:
//管道流
//管道输入流应该连接到管道输出流;管道输入流提供要写入管道输出流的所有数据字节。
//通常,数据由某个线程从 PipedInputStream 对象读取,并由其他线程将其写入到相应的 PipedOutputStream。
//不建议对这两个对象尝试使用单个线程,因为这样可能死锁线程。
//管道输入流包含一个缓冲区,可在缓冲区限定的范围内将读操作和写操作分离开。
//如果向连接管道输出流提供数据字节的线程不再存在,则认为该管道已损坏。
import java.io.IOException;
import java.io.PipedInputStream;
import java.io.PipedOutputStream;
public class PipedStreamDemo02 {
public static void main(String[] args) throws IOException {
//构建输入、输出管道流
PipedInputStream in = new PipedInputStream();
PipedOutputStream out = new PipedOutputStream();
in.connect(out);
Read r = new Read(in);
Write w = new Write(out);
new Thread(r).start();
new Thread(w).start();
}
}
class Read implements Runnable{
private PipedInputStream in;
public Read(PipedInputStream in) {
this.in = in;
}
@Override
public void run() {
try {
byte[] b = new byte[1024];
int len = in.read(b);
String str = new String(b, 0, len);
System.out.println(str);
} catch (Exception e) {
throw new RuntimeException("管道读取流失败");
}
}
}
class Write implements Runnable{
private PipedOutputStream out;
public Write(PipedOutputStream out) {
this.out = out;
}
@Override
public void run() {
try {
out.write("nadadadafafaffwgfwgs".getBytes());
out.close();
} catch (Exception e) {
throw new RuntimeException("管道输出流失败");
}
}
}
四、PrintStream和PrintWriter
示例:
/*
* 打印流:
* 该流提供了打印方法, 可以将各类型的数据都原样打印
*
* 字节打印流:
* PrintStream
* 构造函数可以接受的参数类型:
* 1.file对象. File
* 2.字符串路径. String
* 3.字节输出流. OutputStream
*
* 字符打印流
* PrintWriter
* 构造函数可以接受的参数类型:
* 1.file对象. File
* 2.字符串路径. String
* 3.字节输出流. OutputStream
* 4.字符输出流. Writer
*
*
*/
public class PrintStreamDemo {
public static void main(String[] args) throws IOException {
BufferedReader bufr =
new BufferedReader(new InputStreamReader(System.in));
//参数二: 为true, 表示刷新输出, 只有println、printf 或 format 方法将刷新输出缓冲区
//new FileWriter("D:/printWriter.txt")也会刷新输出的
//这样就不用再写out.flush()
//PrintWriter out = new PrintWriter(new FileWriter("D:/printWriter.txt"),true);
PrintWriter out = new PrintWriter(System.out);
String line = null;
while(null != (line=bufr.readLine())){
if("over".equals(line)) break;
//打印数据
out.println(line);
out.flush();
}
bufr.close();
out.close();
}
}
五、Properties
示例:
import java.io.FileInputStream;
import java.io.FileOutputStream;
import java.io.IOException;
import java.util.Properties;
import java.util.Set;
/*
* Properties是Hashtable的子类
* 也就是说它具备map集合的特点, 而且它里面存储的键值对都是字符串
* 它是集合中和IO相结合的容器集合
*
* 该对象的特点:用于存放键值对形式的配置文件
*
*/
public class PropertiesDemo {
public static void main(String[] args) throws IOException {
loadDemo();
}
public static void setAndGet(){
Properties prop = new Properties();
//设置
prop.setProperty("tom", "男");
prop.setProperty("Jerry", "女");
//获取
String value = prop.getProperty("tom");
// System.out.println(value);
//返回键的Set集合
Set<String> key = prop.stringPropertyNames();
for (String string : key) {
System.out.println(string + " -> " + prop.getProperty(string));
}
}
//将流中的数据存储到集合中
public static void loadDemo() throws IOException{
Properties prop = new Properties();
FileInputStream fis = new FileInputStream("D:/1.txt");
//将流中的数据加载进集合
prop.load(fis);
prop.setProperty("qeqeq", "33");
FileOutputStream os = new FileOutputStream("D:/1.txt");
//将数据写入到输出, 第二个参数为注释
prop.store(os, null);
// System.out.println(prop);
//将列表属性输出到指定的输出流
prop.list(System.out);
os.close();
fis.close();
}
}