1.输入流,只能从中读取数据,而不能向其写出数据。输出流,只能想起写入字节数据,而不能从中读取。
2.InputStream的类型有:
ByteArrayInputStream 包含一个内存缓冲区,字节从中取出。
FileInputStream 从文件中获得字节。
ObjectInputStream 用来恢复被序列化的对象。
PipedInputStream 管道输入流,读取管道内容。多和PipedOutputStream一起用于多线程通信。
SequenceInputStream 是多种输入流的逻辑串联,从第一个输入流读取,直到最后一个输入流。
StringBufferInputStream 读取的字节由字符串提供。
2.OutputStream类型也有如下:
ByteArrayOutputStream 该类实现了一个输出流,其数据被写入由byte数组充当的缓冲区,缓冲区会随着数据的不断写入而自动增长。
FileOutputStream 该类实现了一个输出流,其数据写入文件。
ObjectOutputStream 该类将实现了序列化的对象序列化后写入指定地方。
PipedOutputStream 管道的输出流,是管道的发送端。
3.Objectstream,InputStream经常会和FileInputStream和FileOutputStream一起用。(初始化时用)
ObjectOutputStream objectOutputStream = new ObjectOutputStream(new FileOutputStream("Logon.out"));
4.File类并不是指一个文件,也代表一系列文件的名字,如果代表一个文件集,可用list()方法查询这个集。
5.StreamTokenizer用于将任何InputStream分割为一系列几号,StringTokenizer提供了与 StreamTokenizer极相似的功能,不过是针对字符串的,感觉和C#的split()方法类似。
6.用Zip对文件进行压缩时的步骤:
首先生成压缩文件:
FileOutputStream f = new FileOutputStream("test.zip"); CheckedOutputStream csum = new CheckedOutputStream( f, new Adler32()); ZipOutputStream out = new ZipOutputStream( new BufferedOutputStream(csum));
out.setComment("A test of Java Zipping");//压缩文件注释信息
然后要把要压缩的文件添加进去:
out.putNextEntry(new ZipEntry(test.txt);
之后如果有需要还可以继续向文件中写入别的东西,但必须保证out类中已经有ZipEntry类了。
源代码:
import java.io.*; import java.util.*; import java.util.zip.*; public class ZipCompress { public static void main(String[] args) { try { FileOutputStream fileOutputStream = new FileOutputStream("test.zip"); CheckedOutputStream csum = new CheckedOutputStream(fileOutputStream, new Adler32()); ZipOutputStream outputStream = new ZipOutputStream(new BufferedOutputStream(csum)); outputStream.setComment("A test of java Zipping"); System.out.println("Writing file" + "zip.txt"); BufferedReader in = new BufferedReader(new FileReader("zip.txt")); outputStream.putNextEntry(new ZipEntry("zip.txt")); // int c; // while ((c = in.read()) != -1) { // outputStream.write(c); // } // in.close(); outputStream.write("123".getBytes()); outputStream.close(); System.out.println("Checksum:" + csum.getChecksum().getValue()); System.out.println("Reading file"); FileInputStream fileInputStream = new FileInputStream("test.zip"); CheckedInputStream csumi = new CheckedInputStream(fileInputStream, new Adler32()); ZipInputStream in2 = new ZipInputStream(new BufferedInputStream(csumi)); ZipEntry zipEntry; System.out.println("Checksum:" + csumi.getChecksum().getValue()); while ((zipEntry = in2.getNextEntry()) != null) { System.out.println("Reading file:" + zipEntry); int x; while ((x = in2.read()) != -1) { System.out.println(x); } } in2.close(); ZipFile zf = new ZipFile("test.zip"); Enumeration e = zf.entries(); while (e.hasMoreElements()) { ZipEntry ze2 = (ZipEntry) e.nextElement(); System.out.println("File: " + ze2); } } catch (Exception e) { e.printStackTrace(); } } }
7.Serialization和Externalizable接口的区别,两者都是可以对类进行序列化的接口,不同的是Serialization默认会把对象的所有全都序列化,而Externalizable是可以对序列化的部分进行控制,也就是部分序列化。
8.serialization控制序列化的方法:(1)应用transient(临时)关键字。
(2)我们可以实现 Serializable接口,并添加(注意是“添加”,而非“覆盖”或者“实现”)名为writeObject()和 readObject()的方法。一旦对象被序列化或者重新装配,就会分别调用那两个方法。