一、字节流:
字节流的抽象基类:InputStream和OutputStream
字节流,一次读写一个字节(8位),适用于图片、音视频等文件。【也包括文本文件(注意编码)】
public FileOutputStream(String name) 不存在时会自动创建
public FileOutputStream(File file,boolean append)
public void write(int b) 参数是ASCII表中的码值,不是普通数字
public void write(byte[] b) String对象的getBytes方法
public void write(byte[] b, int off, int len)
注:【字符流的write方法和字节流的write方法的参数不相同】字节流不能直接write(String)
二、字符流
字符流的抽象基类:Reader和Writer
字符流,一次读写两个字节(16位),适用于文本文件、Word文件等unicode字符
public void write(String str)
public void write(char[] cbuf)
public void write(char[] b,int off, int len)
注:【字符流的write方法和字节流的write方法的参数不相同】字符流write的是char数组
字符流存在缓冲区,大小默认为8k,超过就自动写,没超过只有flash或close才会写。
【无论是字节输出流 还是字符输出流,或是缓冲流中的write方法都无法直接写入基本数据类型,因此才有了后面的打印流!!】
三、缓冲流:
1、字节缓冲流
a)public BufferedOutputStream(OutputStream out) 默认大小是8k
b)public BufferedOutputStream(OutputStream out, int size)可以自己指定缓冲区大小,单位字节
c)public BufferedInputStream(InputStream in) 默认缓冲区是8k
d)public BufferedInputStream(InputStream out, int size)可以自己指定缓冲区大小,单位字节
2、字符缓冲流
a)public BufferedWriter(Writer out) 默认大小是8k
b)public BufferedWriter(Writer out, int sz)可以自己指定缓冲区大小,单位字节
特有方法:public void newLine()
c)public BufferedReader(Reader in) 默认大小是8k
d)public BufferedReader(Reader in, int sz)可以自己指定缓冲区大小,单位字节
特有方法:public String readLine() 碰到换行或回车即一行结束
四、转换流:
所有文件最终都是以字节形式存储在硬盘上,但是用户最终操作的是字符,因此字符和字节之间需要按照某种字符编码(ISO-8859-1 UTF-8 GBK)进行转换。
l InputStreamReader 是字节流(读)通向字符流的桥梁,起到转换作用
l OutputStreamWriter 是字符流(写)通向字节流的桥梁,起到转换作用
public InputStreamReader(InputStream in) 默认字符编码
public InputStreamReader(InputStream in, String charsetName)可以自己指定编码
l public String getEncoding() 返回此流使用的字符编码的名称
标准输入输出流:
l System.in的类型是InputStream is=System.in;
l System.out的类型是PrintStream,它是OutputStream的子类OutputStream os=System.out;
字符编码问题:
iso-8859-1 (西方字符)
gbk(国标,gb2312的扩展)
utf-8(国际通用标准)
注意:
new String()时可以指定编码
统一打回原形(byte[]) , 然后new String指定编码
五、装饰设计模式
在不改变原类的前提下扩展该类的功能:
1. 继承(继承复继承,继承何其多,臃肿不堪)
2. 装饰设计模式(层层包装),例如:
BufferedReader br=new BufferedReader(newInputStreamReader(new FileInputStream(...)))
六.递归算法:
1.必须有出口,否则会内存溢出。
2.调用次数不能太多,否则也会内存溢出。
例子:
public static void test(int n)
{
System.out.println(“jaava”);
if(n==0)
return;
test(--n);
}
七.打印流:(输出流,更方便的输出不同类型数据。)
1.PrintStream:字节打印流(继承自OutputStream)底层采用字节流
2.PrintWriter:字符打印流(继承自Writer)底层采用字符流,官方推荐使用。
都有print()和println()方法。
八.Properties(Hashtable的子类)
java.util.Properties专门用于解析“属性配置文件”,可以和IO流结合使用
重要方法:
1. public Object setProperty(String key,String value)设置属性信息
2. public void list(PrintWriter out):将设置的属性信息传入打印流中(只能是打印流)
3. public void store(Writer writer, String comments)将属性信息以写入流形式存储到··,String comments时对信息的描述。
4. public void load(Reader reader) 将读取流读取的配置文件信息导入到Properties对象
九.序列化和反序列化:(把对象以流的形式写入到文件中;将对象以流的形式从文件中读取出来)
实现序列化的条件:
1. 要进行序列化的对象类中必须实现java.io.Serializable接口(来标识jvm序列化功能)
2. 要进行序列化的对象类中必须重写toString()方法。
3. 序列化和反序列化必须要用特定的对象流(ObjectInputStream和ObjectOutputStream)
注:serialVersionUID属性:保证版本的兼容性。(保持固定值)
对象流:
ObjectOutputStream writeObject(Object obj)
ObjectInputStream readObject()
序列化又叫串行化,某个类被串行化,其子类也可以被串行化。 声明为static类型的成员不会被序列化。(静态属于类,不属于对象)。