File类
File类的直接父类是Object类。
一个File类的对象,表示了磁盘上的文件或目录。
1、利用构造方法,指定路径名、文件名等来构造File类的对象。
File file =new File("hello.txt");
但是光用这个语句只是建了一个对象,没有真正产生对应的文件。
还需要 file.createNewFile() 创建出相应的文件。完整如下:
File file =new File("hello.txt");
try {
file.createNewFile();
System.out.println("文件已经建立");
} catch (IOException e) {
System.out.println("文件建立失败");
}
一个File类对象既可以表示目录(文件夹)也可以表示文件。
创建文件是createNewFile()方法,相对应的,创建目录(文件夹)即调用mkdir()方法。
File folder = new File("helloFolder");
folder.mkdir();
如果你创建的是new File("helloFolder/hello/folder")其中三个都是不存在的文件夹,那么你就要用到mkdirs()方法。
因为file的两个可能性,所以有两个函数用于判断File类的对象到底表示什么:
public boolean isDirectory()
public boolean isFile()
2、有了某个文件后,Java的File类提供了方法来操纵文件和获得一个文件的信息。如getName()返回文件名,getParent()返回父目录名,exists()测试文件或目录是否存在等。这些都可以在api文档里面看到。
I/O流
Java程序通过流来进行输入/输出。
输入/输出时,数据在通信通道中流动。
所谓“数据流stream”指的是所有数据通信通道之中,数据的起点和终点。信息的通道就是一个数据流。
1、功能上:输入流和输出流。
2、流结构上:字节流(Byte Streams,以字节为处理单位或称面向字节)和字符流(Character Streams,以字符为处理单位或称面向字符)。
字节流的输入流和输出流基础是InputStream和OutputStream这两个抽象类,字节流的输入输出操作由这两个类的子类实现:FileInputStream...
字符流是以字符为单位进行输入输出处理的流,字符流输入输出的基础是抽象类Reader和Writer。子类:InputStreamReader...
在最底层,所有的输入/输出都是字节形式的。基于字符的流只为处理字符提供方便有效的方法。
关于read方法:
read(byte[] b): 从输入流中读取一定数量的字节,并将其存储在缓冲区数组 b 中。
参数:
b - 存储读入数据的缓冲区。
返回:
读入缓冲区的总字节数;如果因为已经到达流末尾而不再有数据可用,则返回 -1。
read(byte[] b,int off, int len):将输入流中最多 len 个数据字节读入 byte 数组。尝试读取 len 个字节,但读取的字节也可能小于该值。
参数:
b - 读入数据的缓冲区。
off - 数组 b 中将写入数据的初始偏移量。
len - 要读取的最大字节数。
返回:
读入缓冲区的总字节数;如果因为已到达流末尾而不再有数据可用,则返回 -1。
当定好byte[] b的缓冲区,byte[] str = new byte[10],而文件中的内容不止10个字节:
直接fis.read(str);那在缓冲区中的内容就是10个字节。
要读完所有内容,那就写个while():
FileInputStream fis = new FileInputStream(file1);
while(fis.read(str,0,10)!=-1){
System.out.println(new String(str,0,10));
}
file1中的内容是:qwertyuioasdfghjkzxcb
输出的内容是:
qwertyuioa
sdfghjkzxc
bdfghjkzxc
可以看到,每次都是10个字节,但是,在第三次的时候只读到了一个字母“b”,其实也就是说,就把b写入到了缓冲区的b[0]中,而b[1]~b[9]中的内容还是上一次的输入流的内容,不受影响。
【如果有空格、换行,相应的符号都要读进去的】
read(b) 方法的效果等同于:read(b, 0, b.length)
上面的例子中,read(str,0,10)=read(str)