Day7  
 
1.等待唤醒机制 
        什么是等待唤醒机制 
        就是多个线程间的一种协作机制,谈到线程我们线程我们经常想到的是线程间的竞争,比如去争夺锁。 
        在一个线程进行了规定操作后,就进入等待状态(wait)等待其他线程执行完他们的指定代码过后再将其唤醒(notify)在有多个线程进行等待时,如果需要,可以使用notifyAll方法来唤醒所有等待线程 
 
        wait/notify就是线程间的一种协作机制 
2.线程池 
线程池:JDK1.5之后提供的 
java.util.concurrent.Executors [ɪgˈzekjətə(r)]:线程池的工厂类,用来生成线程池 
Executors类中的静态方法: 
    static ExecutorService newFixedThreadPool(int nThreads) 创建一个可重用固定线程数的线程池 
    参数: 
        int nThreads:创建线程池中包含的线程数量 
    返回值: 
        ExecutorService接口,返回的是ExecutorService接口的实现类对象,我们可以使用ExecutorService接口接收(面向接口编程) 
java.util.concurrent.ExecutorService:线程池接口 
    用来从线程池中获取线程,调用start方法,执行线程任务 
        submit(Runnable task) 提交一个 Runnable 任务用于执行 
    关闭/销毁线程池的方法 
        void shutdown() 
线程池的使用步骤: 
    1.使用线程池的工厂类Executors里边提供的静态方法newFixedThreadPool生产一个指定线程数量的线程池 
    2.创建一个类,实现Runnable接口,重写run方法,设置线程任务 
    3.调用ExecutorService中的方法submit,传递线程任务(实现类),开启线程,执行run方法 
    4.调用ExecutorService中的方法shutdown销毁线程池(不建议执行) 
        ExecutorService e = Executors.newFixedThreadPool(3); 
        e.submit(new Runnable()); 
        e.shutdown(); 
3.Lambda表达式 
        函数式编程思想 
        面向对象:注重对象,找对象帮我完成 
        函数式编程思想:注重结果。不在乎是谁帮我完成的 
Lambda表达式的标准格式: 
    由三部分组成: 
        a.一些参数 
        b.一个箭头 
        c.一段代码 
    格式: 
        (参数列表) -> {一些重写方法的代码}; 
    解释说明格式: 
        ():接口中抽象方法的参数列表,没有参数,就空着;有参数就写出参数,多个参数使用逗号分隔 
        ->:传递的意思,把参数传递给方法体{} 
        {}:重写接口的抽象方法的方法体 
Lambda表达式:是可推导,可以省略 
凡是根据上下文推导出来的内容,都可以省略书写 
可以省略的内容: 
    1.(参数列表):括号中参数列表的数据类型,可以省略不写 
    2.(参数列表):括号中的参数如果只有一个,那么类型和()都可以省略 
    3.{一些代码}:如果{}中的代码只有一行,无论是否有返回值,都可以省略({},return,分号) 
        注意:要省略{},return,分号必须一起省略 
 
Day8 
 
1.File类 
java.io.File类 
文件和目录路径名的抽象表示形式。 
java把电脑中的文件和文件夹(目录)封装为了一个File类,我们可以使用File类对文件和文件夹进行操作 
我们可以使用File类的方法 
    创建一个文件/文件夹 
    删除文件/文件夹 
    获取文件/文件夹 
    判断文件/文件夹是否存在 
    对文件夹进行遍历 
    获取文件的大小 
File类是一个与系统无关的类,任何的操作系统都可以使用这个类中的方法 
重点:记住这三个单词 
    file:文件 
    directory:文件夹/目录 
    path:路径 
static String pathSeparator 与系统有关的路径分隔符,为了方便,它被表示为一个字符串。 
static char pathSeparatorChar 与系统有关的路径分隔符。 
static String separator 与系统有关的默认名称分隔符,为了方便,它被表示为一个字符串。 
static char separatorChar 与系统有关的默认名称分隔符。 
操作路径:路径不能写死了 
C:\develop\a\a.txt  windows 
C:/develop/a/a.txt  linux 
"C:"+File.separator+"develop"+File.separator+"a"+File.separator+"a.txt" 
2.路径: 
    绝对路径:是一个完整的路径 
        以盘符(c:,D:)开始的路径 
            c:\\a.txt 
            C:\\Users\itcast\\IdeaProjects\\shungyuan\\123.txt 
            D:\\demo\\b.txt 
    相对路径:是一个简化的路径 
        相对指的是相对于当前项目的根目录(C:\\Users\itcast\\IdeaProjects\\shungyuan) 
        如果使用当前项目的根目录,路径可以简化书写 
        C:\\Users\itcast\\IdeaProjects\\shungyuan\\123.txt-->简化为: 123.txt(可以省略项目的根目录) 
    注意: 
        1.路径是不区分大小写 
        2.路径中的文件名称分隔符windows使用反斜杠,反斜杠是转义字符,两个反斜杠代表一个普通的反斜杠 
3.File类的构造方法 
File(String pathname) 通过将给定路径名字符串转换为抽象路径名来创建一个新 File 实例。 
参数: 
    String pathname:字符串的路径名称 
    路径可以是以文件结尾,也可以是以文件夹结尾 
    路径可以是相对路径,也可以是绝对路径 
    路径可以是存在,也可以是不存在 
    创建File对象,只是把字符串路径封装为File对象,不考虑路径的真假情况 
    File(String parent, String child) 根据 parent 路径名字符串和 child 路径名字符串创建一个新 File 实例。 
参数:把路径分成了两部分 
    String parent:父路径 
    String child:子路径 
好处: 
    父路径和子路径,可以单独书写,使用起来非常灵活;父路径和子路径都可以变化 
File(File parent, String child) 根据 parent 抽象路径名和 child 路径名字符串创建一个新 File 实例。 
参数:把路径分成了两部分 
    File parent:父路径 
    String child:子路径 
好处: 
     父路径和子路径,可以单独书写,使用起来非常灵活;父路径和子路径都可以变化 
     父路径是File类型,可以使用File的方法对路径进行一些操作,再使用路径创建对象 
File类获取功能的方法 
    - public String getAbsolutePath() :返回此File的绝对路径名字符串。 
    - public String getPath() :将此File转换为路径名字符串。 
    - public String getName()  :返回由此File表示的文件或目录的名称。 
    - public long length()  :返回由此File表示的文件的大小。 
File类判断功能的方法 
    - public boolean exists() :此File表示的文件或目录是否实际存在。 
    - public boolean isDirectory() :此File表示的是否为目录。 
    - public boolean isFile() :此File表示的是否为文件。 
File类创建删除功能的方法 
    - public boolean createNewFile() :当且仅当具有该名称的文件尚不存在时,创建一个新的空文件。 
    - public boolean delete() :删除由此File表示的文件或目录。 
    - public boolean mkdir() :创建由此File表示的目录。 
    - public boolean mkdirs() :创建由此File表示的目录,包括任何必需但不存在的父目录。 
File类遍历(文件夹)目录功能 
    - public String[] list() :返回一个String数组,表示该File目录中的所有子文件或目录。 
    - public File[] listFiles() :返回一个File数组,表示该File目录中的所有的子文件或目录。 
注意: 
    list方法和listFiles方法遍历的是构造方法中给出的目录 
    如果构造方法中给出的目录的路径不存在,会抛出空指针异常 
    如果构造方法中给出的路径不是一个目录,也会抛出空指针异常 
4.递归 
递归:方法自己调用自己 
- 递归的分类: 
  - 递归分为两种,直接递归和间接递归。 
  - 直接递归称为方法自身调用自己。 
  - 间接递归可以A方法调用B方法,B方法调用C方法,C方法调用A方法。 
- 注意事项: 
  - 递归一定要有条件限定,保证递归能够停止下来,否则会发生栈内存溢出。 
  - 在递归中虽然有限定条件,但是递归次数不能太多。否则也会发生栈内存溢出。 
  - 构造方法,禁止递归 
递归的使用前提: 
    当调用方法的时候,方法的主体不变,每次调用方法的参数不同,可以使用递归 
5.过滤器 
在File类中有两个和ListFiles重载的方法,方法的参数传递的就是过滤器 
File[] listFiles(FileFilter filter) 
java.io.FileFilter接口:用于抽象路径名(File对象)的过滤器。 
    作用:用来过滤文件(File对象) 
    抽象方法:用来过滤文件的方法 
        boolean accept(File pathname) 测试指定抽象路径名是否应该包含在某个路径名列表中。 
        参数: 
            File pathname:使用ListFiles方法遍历目录,得到的每一个文件对象 
File[] listFiles(FilenameFilter filter) 
java.io.FilenameFilter接口:实现此接口的类实例可用于过滤器文件名。 
    作用:用于过滤文件名称 
    抽象方法:用来过滤文件的方法 
        boolean accept(File dir, String name) 测试指定文件是否应该包含在某一文件列表中。 
        参数: 
            File dir:构造方法中传递的被遍历的目录 
            String name:使用ListFiles方法遍历目录,获取的每一个文件/文件夹的名称 
注意: 
    两个过滤器接口是没有实现类的,需要我们自己写实现类,重写过滤的方法accept,在方法中自己定义过滤的规则 
 
Day09 
 
1.java.io.OutputStream:字节输出流 
    此抽象类是表示输出字节流的所有类的超类。 
定义了一些子类共性的成员方法: 
    - public void close() :关闭此输出流并释放与此流相关联的任何系统资源。 
    - public void flush() :刷新此输出流并强制任何缓冲的输出字节被写出。 
    - public void write(byte[] b):将 b.length字节从指定的字节数组写入此输出流。 
    - public void write(byte[] b, int off, int len) :从指定的字节数组写入 len字节,从偏移量 off开始输出到此输出流。 
    - public abstract void write(int b) :将指定的字节输出流。 
java.io.FileOutputStream extends OutputStream 
2.FileOutputStream:文件字节输出流 
作用:把内存中的数据写入到硬盘的文件中 
构造方法: 
    FileOutputStream(String name)创建一个向具有指定名称的文件中写入数据的输出文件流。 
    FileOutputStream(File file) 创建一个向指定 File 对象表示的文件中写入数据的文件输出流。 
    参数:写入数据的目的 
        String name:目的地是一个文件的路径 
        File file:目的地是一个文件 
    构造方法的作用: 
        1.创建一个FileOutputStream对象 
        2.会根据构造方法中传递的文件/文件路径,创建一个空的文件 
        3.会把FileOutputStream对象指向创建好的文件 
写入数据的原理(内存-->硬盘) 
    java程序-->JVM(java虚拟机)-->OS(操作系统)-->OS调用写数据的方法-->把数据写入到文件中 
字节输出流的使用步骤(重点): 
    1.创建一个FileOutputStream对象,构造方法中传递写入数据的目的地 
    2.调用FileOutputStream对象中的方法write,把数据写入到文件中 
    3.释放资源(流使用会占用一定的内存,使用完毕要把内存清空,提供程序的效率) 
追加写/续写:使用两个参数的构造方法 
    FileOutputStream(String name, boolean append)创建一个向具有指定 name 的文件中写入数据的输出文件流。 
    FileOutputStream(File file, boolean append) 创建一个向指定 File 对象表示的文件中写入数据的文件输出流。 
    参数: 
       String name,File file:写入数据的目的地 
       boolean append:追加写开关 
        true:创建对象不会覆盖源文件,继续在文件的末尾追加写数据 
        false:创建一个新文件,覆盖源文件 
写换行:写换行符号 
    windows:\r\n 
    linux:/n 
    mac:/r 
3,java.io.InputStream:字节输入流 
此抽象类是表示字节输入流的所有类的超类。 
定义了所有子类共性的方法: 
     int read()从输入流中读取数据的下一个字节。 
     int read(byte[] b) 从输入流中读取一定数量的字节,并将其存储在缓冲区数组 b 中。 
     void close() 关闭此输入流并释放与该流关联的所有系统资源。 
 
java.io.FileInputStream extends InputStream 
FileInputStream:文件字节输入流 
作用:把硬盘文件中的数据,读取到内存中使用 
 
构造方法: 
    FileInputStream(String name) 
    FileInputStream(File file) 
    参数:读取文件的数据源 
        String name:文件的路径 
        File file:文件 
    构造方法的作用: 
        1.会创建一个FileInputStream对象 
        2.会把FileInputStream对象指定构造方法中要读取的文件 
 
读取数据的原理(硬盘-->内存) 
    java程序-->JVM-->OS-->OS读取数据的方法-->读取文件 
 
字节输入流的使用步骤(重点): 
    1.创建FileInputStream对象,构造方法中绑定要读取的数据源 
    2.使用FileInputStream对象中的方法read,读取文件 
    3.释放资源 
读取的遍历 
    布尔表达式(len = fis.read())!=-1 
        1.fis.read():读取一个字节 
        2.len = fis.read():把读取到的字节赋值给变量len 
        3.(len = fis.read())!=-1:判断变量len是否不等于-1 
 
int len = 0; //记录读取到的字节 
while((len = fis.read())!=-1){ 
    System.out.print(len);//abc 
} 
字节输入流一次读取多个字节的方法: 
    int read(byte[] b) 从输入流中读取一定数量的字节,并将其存储在缓冲区数组 b 中。 
明确两件事情: 
    1.方法的参数byte[]的作用? 
        起到缓冲作用,存储每次读取到的多个字节 
        数组的长度一把定义为1024(1kb)或者1024的整数倍 
    2.方法的返回值int是什么? 
        每次读取的有效字节个数 
 
使用字节流读取中文文件 
1个中文 
    GBK:占用两个字节 
    UTF-8:占用3个字节 
4.java.io.Reader:字符输入流,是字符输入流的最顶层的父类,定义了一些共性的成员方法,是一个抽象类 
共性的成员方法: 
    int read() 读取单个字符并返回。 
    int read(char[] cbuf)一次读取多个字符,将字符读入数组。 
    void close() 关闭该流并释放与之关联的所有资源。 
java.io.FileReader extends InputStreamReader extends Reader 
FileReader:文件字符输入流 
作用:把硬盘文件中的数据以字符的方式读取到内存中 
构造方法: 
    FileReader(String fileName) 
    FileReader(File file) 
    参数:读取文件的数据源 
        String fileName:文件的路径 
        File file:一个文件 
    FileReader构造方法的作用: 
        1.创建一个FileReader对象 
        2.会把FileReader对象指向要读取的文件 
字符输入流的使用步骤: 
    1.创建FileReader对象,构造方法中绑定要读取的数据源 
    2.使用FileReader对象中的方法read读取文件 
    3.释放资源 
5.java.io.Writer:字符输出流,是所有字符输出流的最顶层的父类,是一个抽象类 
共性的成员方法: 
    - void write(int c) 写入单个字符。 
    - void write(char[] cbuf)写入字符数组。 
    - abstract  void write(char[] cbuf, int off, int len)写入字符数组的某一部分,off数组的开始索引,len写的字符个数。 
    - void write(String str)写入字符串。 
    - void write(String str, int off, int len) 写入字符串的某一部分,off字符串的开始索引,len写的字符个数。 
    - void flush()刷新该流的缓冲。 
    - void close() 关闭此流,但要先刷新它。 
java.io.FileWriter extends OutputStreamWriter extends Writer 
FileWriter:文件字符输出流 
作用:把内存中字符数据写入到文件中 
构造方法: 
    FileWriter(File file)根据给定的 File 对象构造一个 FileWriter 对象。 
    FileWriter(String fileName) 根据给定的文件名构造一个 FileWriter 对象。 
    参数:写入数据的目的地 
        String fileName:文件的路径 
        File file:是一个文件 
    构造方法的作用: 
        1.会创建一个FileWriter对象 
        2.会根据构造方法中传递的文件/文件的路径,创建文件 
        3.会把FileWriter对象指向创建好的文件 
字符输出流的使用步骤(重点): 
    1.创建FileWriter对象,构造方法中绑定要写入数据的目的地 
    2.使用FileWriter中的方法write,把数据写入到内存缓冲区中(字符转换为字节的过程) 
    3.使用FileWriter中的方法flush,把内存缓冲区中的数据,刷新到文件中 
    4.释放资源(会先把内存缓冲区中的数据刷新到文件中) 
6.flush方法和close方法的区别 
    - flush :刷新缓冲区,流对象可以继续使用。 
    - close:  先刷新缓冲区,然后通知系统释放资源。流对象不可以再被使用了。 
7.JDK7的新特性 
在try的后边可以增加一个(),在括号中可以定义流对象 
那么这个流对象的作用域就在try中有效 
try中的代码执行完毕,会自动把流对象释放,不用写finally 
格式: 
    try(定义流对象;定义流对象....){ 
        可能会产出异常的代码 
    }catch(异常类变量 变量名){ 
        异常的处理逻辑 
    } 
 
JDK9新特性 
try的前边可以定义流对象 
在try后边的()中可以直接引入流对象的名称(变量名) 
在try代码执行完毕之后,流对象也可以释放掉,不用写finally 
格式: 
    A a = new A(); 
    B b = new B(); 
    try(a,b){ 
        可能会产出异常的代码 
    }catch(异常类变量 变量名){ 
        异常的处理逻辑 
    } 
8.java.util.Properties集合 extends Hashtable<k,v> implements Map<k,v> 
Properties 类表示了一个持久的属性集。Properties 可保存在流中或从流中加载。 
Properties集合是一个唯一和IO流相结合的集合 
    可以使用Properties集合中的方法store,把集合中的临时数据,持久化写入到硬盘中存储 
    可以使用Properties集合中的方法load,把硬盘中保存的文件(键值对),读取到集合中使用 
 
获取和遍历的方法 
属性列表中每个键及其对应值都是一个字符串。 
    Properties集合是一个双列集合,key和value默认都是字符串 
使用Properties集合存储数据,遍历取出Properties集合中的数据 
Properties集合是一个双列集合,key和value默认都是字符串 
Properties集合有一些操作字符串的特有方法 
    Object setProperty(String key, String value) 调用 Hashtable 的方法 put。 
    String getProperty(String key) 通过key找到value值,此方法相当于Map集合中的get(key)方法 
    Set<String> stringPropertyNames() 返回此属性列表中的键集,其中该键及其对应值是字符串,此方法相当于Map集合中的keySet方法 
(1)可以使用Properties集合中的方法store,把集合中的临时数据,持久化写入到硬盘中存储 
void store(OutputStream out, String comments) 
void store(Writer writer, String comments) 
参数: 
    OutputStream out:字节输出流,不能写入中文 
    Writer writer:字符输出流,可以写中文 
    String comments:注释,用来解释说明保存的文件是做什么用的 
            不能使用中文,会产生乱码,默认是Unicode编码 
            一般使用""空字符串 
使用步骤: 
    1.创建Properties集合对象,添加数据 
    2.创建字节输出流/字符输出流对象,构造方法中绑定要输出的目的地 
    3.使用Properties集合中的方法store,把集合中的临时数据,持久化写入到硬盘中存储 
    4.释放资源 
  (2)可以使用Properties集合中的方法load,把硬盘中保存的文件(键值对),读取到集合中使用 
    void load(InputStream inStream) 
    void load(Reader reader) 
    参数: 
        InputStream inStream:字节输入流,不能读取含有中文的键值对 
        Reader reader:字符输入流,能读取含有中文的键值对 
    使用步骤: 
        1.创建Properties集合对象 
        2.使用Properties集合对象中的方法load读取保存键值对的文件 
        3.遍历Properties集合 
    注意: 
        1.存储键值对的文件中,键与值默认的连接符号可以使用=,空格(其他符号) 
        2.存储键值对的文件中,可以使用#进行注释,被注释的键值对不会再被读取 
        3.存储键值对的文件中,键与值默认都是字符串,不用再加引号 
 
Day10 
 
1.java.io.BufferedOutputStream extends OutputStream 
BufferedOutputStream:字节缓冲输出流 
继承自父类的共性成员方法: 
    - public void close() :关闭此输出流并释放与此流相关联的任何系统资源。 
    - public void flush() :刷新此输出流并强制任何缓冲的输出字节被写出。 
    - public void write(byte[] b):将 b.length字节从指定的字节数组写入此输出流。 
    - public void write(byte[] b, int off, int len) :从指定的字节数组写入 len字节,从偏移量 off开始输出到此输出流。 
    - public abstract void write(int b) :将指定的字节输出流。 
 构造方法: 
    BufferedOutputStream(OutputStream out)  创建一个新的缓冲输出流,以将数据写入指定的底层输出流。 
    BufferedOutputStream(OutputStream out, int size)  创建一个新的缓冲输出流,以将具有指定缓冲区大小的数据写入指定的底层输出流。 
    参数: 
       OutputStream out:字节输出流 
            我们可以传递FileOutputStream,缓冲流会给FileOutputStream增加一个缓冲区,提高FileOutputStream的写入效率 
       int size:指定缓冲流内部缓冲区的大小,不指定默认 
 使用步骤(重点) 
    1.创建FileOutputStream对象,构造方法中绑定要输出的目的地 
    2.创建BufferedOutputStream对象,构造方法中传递FileOutputStream对象对象,提高FileOutputStream对象效率 
    3.使用BufferedOutputStream对象中的方法write,把数据写入到内部缓冲区中 
    4.使用BufferedOutputStream对象中的方法flush,把内部缓冲区中的数据,刷新到文件中 
    5.释放资源(会先调用flush方法刷新数据,第4部可以省略) 
2.java.io.BufferedInputStream extends InputStream 
BufferedInputStream:字节缓冲输入流 
继承自父类的成员方法: 
    int read()从输入流中读取数据的下一个字节。 
    int read(byte[] b) 从输入流中读取一定数量的字节,并将其存储在缓冲区数组 b 中。 
    void close() 关闭此输入流并释放与该流关联的所有系统资源。 
构造方法: 
    BufferedInputStream(InputStream in) 创建一个 BufferedInputStream 并保存其参数,即输入流 in,以便将来使用。 
    BufferedInputStream(InputStream in, int size) 创建具有指定缓冲区大小的 BufferedInputStream 并保存其参数,即输入流 in,以便将来使用。 
    参数: 
        InputStream in:字节输入流 
            我们可以传递FileInputStream,缓冲流会给FileInputStream增加一个缓冲区,提高FileInputStream的读取效率 
        int size:指定缓冲流内部缓冲区的大小,不指定默认 
使用步骤(重点): 
    1.创建FileInputStream对象,构造方法中绑定要读取的数据源 
    2.创建BufferedInputStream对象,构造方法中传递FileInputStream对象,提高FileInputStream对象的读取效率 
    3.使用BufferedInputStream对象中的方法read,读取文件 
    4.释放资源 
3.java.io.BufferedWriter extends Writer 
BufferedWriter:字符缓冲输出流 
继承自父类的共性成员方法: 
    - void write(int c) 写入单个字符。 
    - void write(char[] cbuf)写入字符数组。 
    - abstract  void write(char[] cbuf, int off, int len)写入字符数组的某一部分,off数组的开始索引,len写的字符个数。 
    - void write(String str)写入字符串。 
    - void write(String str, int off, int len) 写入字符串的某一部分,off字符串的开始索引,len写的字符个数。 
    - void flush()刷新该流的缓冲。 
    - void close() 关闭此流,但要先刷新它。 
构造方法: 
    BufferedWriter(Writer out) 创建一个使用默认大小输出缓冲区的缓冲字符输出流。 
    BufferedWriter(Writer out, int sz) 创建一个使用给定大小输出缓冲区的新缓冲字符输出流。 
    参数: 
        Writer out:字符输出流 
            我们可以传递FileWriter,缓冲流会给FileWriter增加一个缓冲区,提高FileWriter的写入效率 
        int sz:指定缓冲区的大小,不写默认大小 
特有的成员方法: 
    void newLine() 写入一个行分隔符。会根据不同的操作系统,获取不同的行分隔符 
    换行:换行符号 
    windows:\r\n 
    linux:/n 
    mac:/r 
 使用步骤: 
    1.创建字符缓冲输出流对象,构造方法中传递字符输出流 
    2.调用字符缓冲输出流中的方法write,把数据写入到内存缓冲区中 
    3.调用字符缓冲输出流中的方法flush,把内存缓冲区中的数据,刷新到文件中 
    4.释放资源 
4.java.io.BufferedReader extends Reader 
BufferedReader:字符缓冲输入流 
继承自父类的共性成员方法: 
    int read() 读取单个字符并返回。 
    int read(char[] cbuf)一次读取多个字符,将字符读入数组。 
    void close() 关闭该流并释放与之关联的所有资源。 
 构造方法: 
    BufferedReader(Reader in)  创建一个使用默认大小输入缓冲区的缓冲字符输入流。 
    BufferedReader(Reader in, int sz)     创建一个使用指定大小输入缓冲区的缓冲字符输入流。 
    参数: 
        Reader in:字符输入流 
            我们可以传递FileReader,缓冲流会给FileReader增加一个缓冲区,提高FileReader的读取效率 
 特有的成员方法: 
    String readLine() 读取一个文本行。读取一行数据 
        行的终止符号:通过下列字符之一即可认为某行已终止:换行 ('\n')、回车 ('\r') 或回车后直接跟着换行(\r\n)。 
    返回值: 
        包含该行内容的字符串,不包含任何行终止符,如果已到达流末尾,则返回 null 
 使用步骤: 
    1.创建字符缓冲输入流对象,构造方法中传递字符输入流 
    2.使用字符缓冲输入流对象中的方法read/readLine读取文本 
    3.释放资源 
5.java.io.OutputStreamWriter extends Writer 
OutputStreamWriter: 是字符流通向字节流的桥梁:可使用指定的 charset 将要写入流中的字符编码成字节。(编码:把能看懂的变成看不懂) 
 
继续自父类的共性成员方法: 
    - void write(int c) 写入单个字符。 
    - void write(char[] cbuf)写入字符数组。 
    - abstract  void write(char[] cbuf, int off, int len)写入字符数组的某一部分,off数组的开始索引,len写的字符个数。 
    - void write(String str)写入字符串。 
    - void write(String str, int off, int len) 写入字符串的某一部分,off字符串的开始索引,len写的字符个数。 
    - void flush()刷新该流的缓冲。 
    - void close() 关闭此流,但要先刷新它。 
构造方法: 
    OutputStreamWriter(OutputStream out)创建使用默认字符编码的 OutputStreamWriter。 
    OutputStreamWriter(OutputStream out, String charsetName) 创建使用指定字符集的 OutputStreamWriter。 
    参数: 
        OutputStream out:字节输出流,可以用来写转换之后的字节到文件中 
        String charsetName:指定的编码表名称,不区分大小写,可以是utf-8/UTF-8,gbk/GBK,...不指定默认使用UTF-8 
使用步骤: 
    1.创建OutputStreamWriter对象,构造方法中传递字节输出流和指定的编码表名称 
    2.使用OutputStreamWriter对象中的方法write,把字符转换为字节存储缓冲区中(编码) 
    3.使用OutputStreamWriter对象中的方法flush,把内存缓冲区中的字节刷新到文件中(使用字节流写字节的过程) 
    4.释放资源 
6.java.io.InputStreamReader extends Reader 
InputStreamReader:是字节流通向字符流的桥梁:它使用指定的 charset 读取字节并将其解码为字符。(解码:把看不懂的变成能看懂的) 
继承自父类的共性成员方法: 
    int read() 读取单个字符并返回。 
    int read(char[] cbuf)一次读取多个字符,将字符读入数组。 
    void close() 关闭该流并释放与之关联的所有资源。 
构造方法: 
    InputStreamReader(InputStream in) 创建一个使用默认字符集的 InputStreamReader。 
    InputStreamReader(InputStream in, String charsetName) 创建使用指定字符集的 InputStreamReader。 
    参数: 
        InputStream in:字节输入流,用来读取文件中保存的字节 
        String charsetName:指定的编码表名称,不区分大小写,可以是utf-8/UTF-8,gbk/GBK,...不指定默认使用UTF-8 
 使用步骤: 
    1.创建InputStreamReader对象,构造方法中传递字节输入流和指定的编码表名称 
    2.使用InputStreamReader对象中的方法read读取文件 
    3.释放资源 
 注意事项: 
    构造方法中指定的编码表名称要和文件的编码相同,否则会发生乱码 
7.序列化和反序列化 
java.io.ObjectOutputStream extends OutputStream 
ObjectOutputStream:对象的序列化流 
作用:把对象以流的方式写入到文件中保存 
构造方法: 
    ObjectOutputStream(OutputStream out) 创建写入指定 OutputStream 的 ObjectOutputStream。 
    参数: 
        OutputStream out:字节输出流 
特有的成员方法: 
    void writeObject(Object obj) 将指定的对象写入 ObjectOutputStream。 
使用步骤: 
    1.创建ObjectOutputStream对象,构造方法中传递字节输出流 
    2.使用ObjectOutputStream对象中的方法writeObject,把对象写入到文件中 
    3.释放资源 
8.java.io.ObjectInputStream extends InputStream 
ObjectInputStream:对象的反序列化流 
作用:把文件中保存的对象,以流的方式读取出来使用 
构造方法: 
    ObjectInputStream(InputStream in) 创建从指定 InputStream 读取的 ObjectInputStream。 
    参数: 
        InputStream in:字节输入流 
特有的成员方法: 
    Object readObject() 从 ObjectInputStream 读取对象。 
使用步骤: 
    1.创建ObjectInputStream对象,构造方法中传递字节输入流 
    2.使用ObjectInputStream对象中的方法readObject读取保存对象的文件 
    3.释放资源 
    4.使用读取出来的对象(打印) 
 readObject方法声明抛出了ClassNotFoundException(class文件找不到异常) 
 当不存在对象的class文件时抛出此异常 
 反序列化的前提: 
    1.类必须实现Serializable 
    2.必须存在类对应的class文件 
9.序列化和反序列化的时候,会抛出NotSerializableException没有序列化异常 
类通过实现 java.io.Serializable 接口以启用其序列化功能。未实现此接口的类将无法使其任何状态序列化或反序列化。 
Serializable接口也叫标记型接口 
    要进行序列化和反序列化的类必须实现Serializable接口,就会给类添加一个标记 
    当我们进行序列化和反序列化的时候,就会检测类上是否有这个标记 
        有:就可以序列化和反序列化 
        没有:就会抛出 NotSerializableException异常 
去市场买肉-->肉上有一个蓝色章(检测合格)-->放心购买-->买回来怎么吃随意 
static关键字:静态关键字 
    静态优先于非静态加载到内存中(静态优先于对象进入到内存中) 
    被static修饰的成员变量不能被序列化的,序列化的都是对象 
    private static int age; 
    oos.writeObject(new Person("小美女",18)); 
    Object o = ois.readObject(); 
    Person{name='小美女', age=0} 
transient关键字:瞬态关键字 
    被transient修饰成员变量,不能被序列化 
    private transient int age; 
    oos.writeObject(new Person("小美女",18)); 
    Object o = ois.readObject(); 
    Person{name='小美女', age=0} 
 
10.java.io.PrintStream:打印流 
    PrintStream 为其他输出流添加了功能,使它们能够方便地打印各种数据值表示形式。 
PrintStream特点: 
    1.只负责数据的输出,不负责数据的读取 
    2.与其他输出流不同,PrintStream 永远不会抛出 IOException 
    3.有特有的方法,print,println 
        void print(任意类型的值) 
        void println(任意类型的值并换行) 
构造方法: 
    PrintStream(File file):输出的目的地是一个文件 
    PrintStream(OutputStream out):输出的目的地是一个字节输出流 
    PrintStream(String fileName) :输出的目的地是一个文件路径 
PrintStream extends OutputStream 
继承自父类的成员方法: 
    - public void close() :关闭此输出流并释放与此流相关联的任何系统资源。 
    - public void flush() :刷新此输出流并强制任何缓冲的输出字节被写出。 
    - public void write(byte[] b):将 b.length字节从指定的字节数组写入此输出流。 
    - public void write(byte[] b, int off, int len) :从指定的字节数组写入 len字节,从偏移量 off开始输出到此输出流。 
    - public abstract void write(int b) :将指定的字节输出流。 
注意: 
    如果使用继承自父类的write方法写数据,那么查看数据的时候会查询编码表 97->a 
    如果使用自己特有的方法print/println方法写数据,写的数据原样输出 97->97 
    可以改变输出语句的目的地(打印流的流向) 
    输出语句,默认在控制台输出 
    使用System.setOut方法改变输出语句的目的地改为参数中传递的打印流的目的地 
        static void setOut(PrintStream out) 
          重新分配“标准”输出流。 |   
        
 
    
    
    
     
 
 |