论坛首页 Java企业应用论坛

流与文件之学习笔记

浏览 5474 次
精华帖 (0) :: 良好帖 (2) :: 新手帖 (14) :: 隐藏帖 (0)
作者 正文
   发表时间:2011-05-04   最后修改:2011-05-04

1.        输入流和输出流以字节为单位读取,抽象类是 InputStream OutputStream

2.        抽象类 Reader Writer 的读入和写出操作都是基于两字节的 Unicode 码元的。

3.        InputStream 类有一个抽象方法 read ,该方法读入一个字节,并返回读入的字节,或者在遇到输入源结构末尾的时返回 -1 。所有的输入类都必须覆盖这个方法。

4.        OutputStream 类有一个抽象方法 write ,该方法输出一个字节。同样所有的输出类都必须覆盖这个方法。

5.        read write 方法在执行时都将阻塞,直至字节确实被读入或写出。

6.        available 方法可以去检查当前可用于读入的字节数量

7.        完成读写操作时,应该调用 close 方法来关闭它,目的是释放操作系统的资源。 Flush 方法用于清空输出流。

8.        java 提供了众多基本的 InputStream OutputStream 类导出的类,这些类可以处理那些常用格式的数据,而不只是在字节级别上表示的数据。

9.        JDK5 引入了 Closeable Flushable Readable Appendable 四个接口,其中只有 Writer 实现了 Appendable 接口

10.    使用 System.getProperty(“user.dir”) 来获得用户工作目录

11.    JAVA IO 使用了 Decorator 模式 ,可以将几个输入或者输出流的功能组合到一起。比如我们想使用缓存机制,以及用于文件的数据输入,要实现这个功能,应该如下方法来写: DataInputStream din=new DataInputStream(new BufferedInputStream(new FileInputStream(“employee.dat”)))

12.    输入流的预先预览可以用 PushbackInputStream 类来实现。如果不是期望的值可以将读入的字节回推到输入流中

13.    OutputStreamWriter 类将使用选定的字符编码方式,把 Unicode 字符流转换为字节流。相反地, InputStreamReader 类将包含字节的输入流转换为可以产生 Unicode 字符的读入器

14.    以二进制格式写出数据,需要使用 DataOutputStream 。以文本格式写出数据,需要使用 PrintWriter

15.    文本格式数据的读入在 JDK5.0 之前惟一方式就是 BufferedReader 类, JDK5.0 之后可以使用 Scanner 类来实现。建议使用 Scanner 类。

16.    Java SE 1.4 开始引入的 java . nio 包用引入的 Charset 类统一了对字符集的转换

17.    字符集建立了两字节 Unicode 码元序列与使用本地字符编码方式的字节序列之间的映射。

18.    本地编码方式模式不能表示所有的 Unicode 字符,如果某个字符不能表示,它将被转换成?。

19.    二进制文件的写出可以使用实现了 DataOutput 接口的 DataOutputStream ,写入使用实现了 DataInput 接口的 DataInputStream

20.    RandomAccessFile 类可以在文件中的任何位置查找或写入数据。在打开随机访问文件时,只用于读入或者同时用于读写时,我们可以通过使用字符串“ r ”或者“ rw ”作为构造器的第二个参数来指定这个选项。

21.    java 中可以使用 ZipInputStream 来读入 ZIP 文档,浏览压缩文件中单独的项的时候可以使用 getNextEntry 方法就可以返回一个描述这些项的 ZipEntry 类型的对象。典型读取 ZIP 文件的代码:

 

ZipInputStream zin = new ZipInputStream(new FileInputStream(zipname));

ZipEntry entry;

while((entry = zin.getNextEntry) != null){

              // Analyze entry

//Read the contents of zin;

zin.closeEntry();

}

zin.close();
 

22.    java 中写出到 ZIP 文件用 ZipOutputStream 而对于你希望放入到 ZIP 文件中的每一项,都应该创建一个 ZipEntry 对象,并将文件名传递给 ZipEntry 的构造器,它将设置其他诸如文件日期和解压方法等参数。如果需要,你可以覆盖这些设置。然后,你需要调用 ZipOutputStream putNextEntry 方法来开始写出新文件,并将文件数据发送到 ZIP 流中。当完成时,需要调用 closeEntry

 

FileOutputStream fout = new FileOutputStream(“test.zip”);

ZipOutputStream zout = new ZipOutputStream(fout);

for all files{

        ZipEntry ze = new ZipEntry(filename);

        zout.putNextEntry(ze);

        send data to zout;

        zout.closeEntry();

}

zout.close();
 

23.    ObjectInputStream ObjectOutputStream 可以操作对象的读入和写出。但要对被存储或恢复的所有类进行修改,这些类就必须实现 Serializable 接口。 Serializable 接口没有任何方法。

24.    每个对象序列化保存不是用对象的地址,而是用一个序列号( serial number )保存的。所以我们把这种机制称为对象序列化。

25.    对象序列化的算法为:

l         对你遇到的每一个对象引用都关联一个序列号。

l         对于每个对象,当第一次遇到时,保存其对象数据到流中。

l         如果某个对象之前已经被保存过,那么只写出“与之前保存过序列号为 x 的对象相同”。在读回对象时,整个过程是反过来的。

l         对于流中的对象,在第一次遇到其序列号时,构建它,并使用流中数据来初始化它,然后记录这个顺序号和新对象之间的关联。

l         当遇到“与之前保存过的序列号为 x 的对象相同”标记时,获取与这个顺序号相关联的对象引用。

26.    流类关心的是文件的内容,而 File 类关心的是在磁盘上文件的存储。 File 类可以用来查询文件最后的修改时间,移除或重命名文件。

27.    为了考虑文件操作的平台可移植性问题,文件的分隔符最好用常量字符串 File.separator 形式来存储。

28.    File 对象既可以表示文件,也可以表示目录。

29.    在处理文件或者目录名时,应该总是使用 File 对象而不是字符串。这样做的好处很多,如: File 类的 equal 方法指导某些文件系统不是大小写敏感的,或者在目录名尾部的(是无关紧要的)。

30.    在使用 File 类的 list 方法的时候,可以使用 FileNameFilter 对象作为参数来减少列表长度。而不是列出目录中所有的文件。

31.    Java1.4 引入了大量用于改进输入 / 输出处理机制的特性。它们位于 java.nio 包中,合称“新 I/O ”。主要包括一下特性

l         字符集编码器和解码器

l         非阻塞的 I/O

l         内存映射文件

l         文件加锁机制

32.    java.nio 包使内存映射变得十分简单,首先通过 FileInputStream FileOutputStream RandomAccessFile 类通过 getChannel 方法获得通道。通道是用于磁盘文件的一种抽象。然后通过调用 FileChannel 类的 map 方法从磁盘中获得一个 MappedByteBuffer 。一旦有了缓冲区,就可以使用 ByteBuffer 类和 Buffer 超类的方法读写数据了。缓冲区支持顺序和随机数据访问,它有一个可以通过 get put 操作来推动的位置。

33.    缓冲区是由具有相同类型的数值构成的数组, Buffer 类是一个抽象类,它有众多的具体子类,包括 ByteBuffer CharBuffer DoubleBuffer IntBuffer,LongBuffer ShortBuffer 。但要注意 StringBuffer 与这些缓冲区没有关系。在实际中常用 ByteBuffer CharBuffer

34.    每个缓冲区都具有:

l         一个容量,它永远不能改变。

l         一个读写位置,下一个值将在此进行读写。

l         一个界限,超过它进行读写是没有意义的。

l         一个可选的标记,用于重复一个读入或写出操作。

这些值满足下面条件

0<= 标记 <= 位置 <= 界限 <= 容量

35.    使用缓冲区的主要目的是执行“写,然后读入”循环。

36.    要锁定一个文件,可以调用 FileChannel 类的 lock tryLock 方法:

FileLock lock = channel . lock ();

FileLock lock = channel . tryLock();

第一个调用会阻塞直至可获得锁,而第二个调用将立即返回,要么返回锁,要么在锁不可获得的情况下返回 null 。另外也可以锁定文件的一部分。与锁定文件的方法名一样,只是传递的参数不同。

37.    文件加锁机制是依赖于操作系统的。所以应该避免使用文件夹锁。

   发表时间:2011-05-05  
LZ介绍的还挺详细的..
学习了不少东西,谢谢
0 请登录后投票
   发表时间:2011-05-06  
很好,看到了一些平常用得不多的知识。谢谢LZ
0 请登录后投票
   发表时间:2011-05-06  
不错,很受用
0 请登录后投票
   发表时间:2011-05-06  
精神是可嘉的,可是你不知道JE很多人都是大牛么?已经七票新手帖了。。
0 请登录后投票
   发表时间:2011-05-06  
建议je开一个菜鸟专区和一个大牛专区。
0 请登录后投票
   发表时间:2011-05-07  
很基础的支持 就当再复习一遍啊
0 请登录后投票
   发表时间:2011-05-09  
恩 感谢LZ,最近正在学习IO相关的。
0 请登录后投票
   发表时间:2011-05-09  
很多人 都自认为不是菜鸟? 你真的都熟悉 楼主说的这些内容吗
也就是用到的时候才去google的吧,
0 请登录后投票
论坛首页 Java企业应用版

跳转论坛:
Global site tag (gtag.js) - Google Analytics