非流式部分
File类
在Java语言的java.io包中,由File类提供了描述文件和目录的操作与管理方法。但File类不是InputStream、OutputStream或Reader、Writer的子类,因为它不负责数据的输入输出,而专门用来管理磁盘文件与目录。
作用:File类主要用于命名文件、查询文件属性和处理文件目录。
public class File extends Object
implements Serializable,Comparable{}
File类共提供了三个不同的构造函数,以不同的参数形式灵活地接收文件和目录名信息。
构造函数:
1)File (String pathname)
例:File f1=new File("FileTest1.txt"); //创建文件对象f1,f1所指的文件是在当前目录下创建的FileTest1.txt
2)File (String parent , String child)
例:File f2=new File(“D:\\dir1","FileTest2.txt") ;// 注意:D:\\dir1目录事先必须存在,否则异常
3)File (File parent , String child)
例:
File f4=new File("\\dir3");
File f5=new File(f4,"FileTest5.txt"); //在如果 \\dir3目录不存在使用f4.mkdir()先创建
一个对应于某磁盘文件或目录的File对象一经创建, 就可以通过调用它的方法来获得文件或目录的属性。
public static void main(String[] args)
{String fileName = "D:" + File.separator + "Files";
File file = new File(fileName);
if (file.exists() && file.isDirectory()) // 判断路径指向的文件/文件夹是否存在、是否目录
{
System.out.println("file是一个文件夹\n");
File[] files = file.listFiles(); // 获取目录下的所有文件/文件夹(仅该层路径下)
System.out.print("路径下有文件:");
for (File f : files)
{System.out.print(f + "\t");
}
System.out.println();
System.out.println("files[0]的文件名:" + files[0].getName()); // 获取文件名、文件夹名
System.out.println("files[0]的文件路径:" + files[0].getPath()); // 获取文件、文件夹路径
System.out.println("files[0]的绝对路径:" + files[0].getAbsolutePath()); // 获取文件、文件夹绝对路径
System.out.println("files[0]的父文件夹名:" + files[0].getParent()); // 获取文件父目录路径
System.out.println(files[0].exists() ? "files[0]的存在" : "files[0]的不存在"); // 判断文件、文件夹是否存在
System.out.println(files[0].canWrite() ? "files[0]的可写" : "files[0]的不可写"); // 判断文件是否可写
System.out.println(files[0].canRead() ? "files[0]的可读" : "files[0]的不可读"); // 判断文件是否可读
System.out.println(files[0].canExecute() ? "file[0]可执行" : "file[0]不可执行"); // 判断文件是否可执行
System.out.println(files[0].isDirectory() ? "files[0]的是目录" : "files[0]的不是目录"); // 判断文件、文件夹是不是目录
System.out.println(files[0].isFile() ? "files[0]的是文件" : "files[0]的不是文件"); // 判断拿文件、文件夹是不是标准文件
System.out.println(files[0].isAbsolute() ? "files[0]的路径名是绝对路径" : "files[0]的路径名不是绝对路径"); // 判断路径名是不是绝对路径
System.out.println("files[0]的最后修改时间:" + files[0].lastModified()); // 获取文件、文件夹上一次修改时间
System.out.println("files[0]的大小:" + files[0].length() + " Bytes"); // 获取文件的字节数,如果是一个文件夹则这个值为0
System.out.println("files[0]的路径转换为URI:" + files[0].toURI()); // 获取文件路径URI后的路径名
if (files[0].exists())
files[0].delete(); // 删除指定的文件、文件夹
if (files[1].exists())
files[1].deleteOnExit(); // 当虚拟机终止时删除指定的文件、文件夹
}
}
运行结果为:
file是一个文件夹
路径下有文件:D:\Files\buffered.txt D:\Files\example.txt D:\Files\Inner D:\Files\serializable.txt D:\Files\stream.txt D:\Files\test.txt
files[0]的文件名:buffered.txt
files[0]的文件路径:D:\Files\buffered.txt
files[0]的绝对路径:D:\Files\buffered.txt
files[0]的父文件夹名:D:\Files
files[0]的存在
files[0]的可写
files[0]的可读
file[0]可执行
files[0]的不是目录
files[0]的是文件
files[0]的路径名是绝对路径
files[0]的最后修改时间:1440313521120
files[0]的大小:21 Bytes
files[0]的路径转换为URI:file:/D:/Files/buffered.txt
示例代码应该是比较全面地演示了File的用法,其中有两点值得注意:
1、程序代码的第三行,写"D:/Files"和"D:\\Files"都是可以的,但像示例代码这么写应该是一种更好的做法,因为这么写使得代码 的跨平台型、健壮性更好。"File.separator"会根据不同的操作系统取不同操作系统下的分隔符。其实File还有另一个分隔符 pathSeparator,表示":",不过因为Java主要用在Windows和Linux下,Linux下没有盘符的问题,所以一般直接打":"就 好了
2、程序代码的第34、第36行,注意一下,删除的如果是一个文件夹的话,文件夹下还有文件/文件夹,是无法删除成功的
最后,再次重申,File是IO流的基础。
来源: http://www.cnblogs.com/szlbm/p/5513117.html
RandomAccessFile 类
RandomAccessFile类可以说是Java语言中功能最为丰富的文件访 问类,它提供了众多的文件访问方法。RandomAccessFile类支持"随机访问"方式,可以跳转到文件的任意位置处读写数据。要访问一个文件的时 候,不想把文件从头读到尾,而是希望像访问一个数据库一样地访问一个文本文件,使用RandomAccessFile类是最佳选择。
RandomAccessFile对象类中有个位置指示器,指向当前读写处的位置,当读写n个字节后,文件指示器将指向这n个字节后的下一个字节处。刚打开文件时,文件指示器指向文件的开头处,可以移动文件指示器到新的位置,随后的读写将从新的位置开始。
RandomAccessFile类在文件随机(相对于顺序)读取时有很大的优势,但该类仅限于操作文件,不能访问其他得IO设备,如网络、内存映像等。
RandomAccessFile类为用户提供了两种构造方法:
1、RandomAccessFile(File file, String mode)
2、RandomAccessFile(String name, String mode)
其实第二种构造方法也是new一个File出来再调用第一种构造方法,建议使用第 一种构造方法,因为第一篇文章就说了File是IO的基础,有一个File不仅仅可以通过RandomAccessFile对文件进行操作,也可以通过 File对象对文件进行操作。至于mode,Java给开发者提供了四种mode:
注意第二点"rw"模式,对rw模式的解释意味着Java并不强求指定的路径下一定存在某个文件,假如文件不存在,会自动创建
RandomAccessFile中有如下一些常用方法:
RandomAccessFile使用实例
先定义一个实体类:
第一部分,写文件,该文件在路径下并没有,所以Java会自动帮我们创建:
Employee e1 = new Employee("zhangsan", 23);
Employee e2 = new Employee("lisi", 24);
Employee e3 = new Employee("wangwu", 25);
RandomAccessFile raf0 = new RandomAccessFile("D:/employee.txt", "rw");
raf0.writeBytes(e1.getName());
raf0.writeInt(e1.getAge());
raf0.writeBytes(e2.getName());
raf0.writeInt(e2.getAge());
raf0.writeBytes(e3.getName());
raf0.writeInt(e3.getAge());
raf0.close();
文件创建好了,D盘下也有该文件了,所以读取一下,这里使用了一些小技巧来演示seek方法和skipBytes方法:
RandomAccessFile raf1 = new RandomAccessFile("D:/employee.txt", "r");
int len = 8;
raf1.skipBytes(12); // 跳过第一个员工的信息,其姓名8字节,年龄4字节
System.out.println("第二个员工的信息:");
String str = "";
for (int i = 0; i < len; i++){
str = str + (char)raf1.readByte();
}
System.out.println("name:" + str);
System.out.println("age:" + raf1.readInt());
System.out.println("第一个员工的信息:");
raf1.seek(0);
str = "";
for (int i = 0; i < len; i++){
str = str + (char)raf1.readByte();
}
System.out.println("name:" + str);
System.out.println("age:" + raf1.readInt());
System.out.println("第三个员工的信息:");
raf1.skipBytes(12); // 跳过第二个员工的信息
str = "";
for (int i = 0; i < len; i++){
str = str + (char)raf1.readByte();
}
System.out.println("name:" + str.trim());
System.out.println("age:" + raf1.readInt());
raf1.close();
看一下运行结果:
第二个员工的信息:
name:lisi
age:24
第一个员工信息:
name:zhangsan
age:23
第三个员工信息:
name:wangwu
age:25
可能有人奇怪,"zhangsan"加上一个int跳过12个字节可以理解,但是"lisi"、"wangwu"为什么加上int要跳过12个字节 呢?明明"lisi"只有4个字节,"wangwu"只有6个字节啊。这个就涉及到一个"字节对齐"的问题了,有兴趣的可以了解一下。另外,再说一 下,RandomAccessFile使用完一定要及时close()。