一、文件的编码

              开发时一定要注意项目默认的编码!!!!!!!!
              文件操作的时候一定要记得关闭!!!!!!!!
       ASCII:美国标准信息交换码,用一个字节的7位可以表示一个字符
       ISO8859-1:拉丁码表,西欧标准字符集,用一个字节的8位表示
       GB2312:中文编码表,用两个字节来表示中文编码
       GBK:中文编码表的升级,融合了更多表示中文文字符号
       GB18030:GBK的取代版本
       BIG-5:同行与港台地区,是繁体字编码方案,俗称“大五码”
       Uicode:国际标准码,融合了多种文字
       UTF-8:是Unicode编码的实现方式,最多用三个字节来表示一个字符
    
       GBK编码     中文占用2个字节,英文占用1个字节
       UTF-8编码   中文占用3个字节,英文占用1个字节
       UTF-16be编码中文占用2个字节,英文占用2个字节
       Java是双字节编码 utf-16be,即java中每个字符占用两个字节
       
       当你想把一个字节序列变成一个字符串时,字节序列使用什么编码,就需要使用什么编码去显示的调用s.getBytes("字节序列的编码格式");,否则会出现乱码
 
       文本文件就是字节序列,可以是任意编码的字节序列,但是如果是在中文机器上直接创建文本文件,那么该文本文件只认识ANSI(本地编码)编码。如,新建一个TXT文件,内容为联通,打开则会出现乱码,是一种巧合,正好符合了UTF-8编码的规则
   

       Integer.toHexString(Byte);//以十六进制的方式显示

二、File工具类的使用
         1、File类用于表示文件和目录都可以
            File类只用于表示文件(目录)的信息(名称、大小等),不能用于文件内容的访问
         2、File类的基本API(看手册)
                构造函数的情况
                创建功能:createNewFile(),mkdir(),mkdirs()
                删除功能:delete()
                重命名功能:renameTo()
                判断功能:isFile(),isDirectory(),exists()等
                获取功能:getName(),getPath(),list()等
                文件过滤器的作用:list(FilenameFilter filter),返回满足指定条件的文件列表
                
            判断参数的时候,可以使用IllegalArgumentException参数抛出异常
            File.separator设置目录分隔符,Windows、Unix都识别
            相对目录是当前目录,也即在项目的根目录下
         3、遍历目录(递归 dir.listFiles())
            访问文件系统的时候因为是与JVM以外的资源进行交互,所以,写代码一定要严谨,把各种情况考虑到了
             
三、RandomAccessFile类的使用
       1、RandomAccessFile java提供的对文件内容的访问,既可以读,也可以写
          且支持随机访问文件,可以访问文件的任意位置
       2、Java文件模型
             在硬盘上的文件是byte byte byte存储的,是数据的集合
       3、打开文件 
1 RandomAccessFile raf =newRandomAccessFile(file,"rw");//rw,读写,r只读
2 //打开文件时,文件指针在开头,pointer = 0;
3 raf.write(byte);//write方法只会写一个字节,同时直接指针指向下一个位置
4 int b = raf.read();//每次读一个字节,java中每个字符占用两个字节,使用右移8位的方式分次写入
5 raf.seek(指针位置);//移动指针
6 raf.close();//文件读写完一定要关闭,否则可能会有意想不到的后果
在文件下载文件的时候,这种方式有很大的好处,每个线程下载文件的一部分,
          然后再拼接在一起,迅雷就是使用的这种方式,会记录指针的位置
 
四、字节流(InputStream、OutputStream,两个都是抽象类)
         1、I/O流用来处理设备之间的数据传输
            InputStream抽象了应用程序读取数据的方式
            OutputStream抽象了应用程序写出数据的方式
         2、EOF = End  读到 -1 就读到结尾
         3、输入流的基本方式主要是读
              int b = in.read();//读取一个字节无符号填充到int第八位,-1是EOF
              in.read(byte[] buf);//读入多个字节填充的字节数组
         4、输出流的基本方式主要是写
              out.write(int b);
              out.write(byte[] buf);
         5、FileInputStream具体实现了文件的读取操作
                while((b=in.read())!=-1){读一个文件}
                in.close();//一定要记得关闭流释放系统资源
                批量读取(速度非常快,效率高) vs. 单字节读取(不适合读大文件,效率很低)
          6、FileOutputStream具体实现了向文件中写数据的操作
                是删除文件重新创建,还是在原文件上追加内容,看构造方法
                自己实现文件的copy操作
                out.flush();
                out.close();
          7、数据输入输出流DataOutputStream/DataInputStream
                对流功能的扩展,是一个包装类,可以更加方便的读取int,long,字符等类型数据,本质是使用的一种装饰模式实现的
         8、字节缓冲流BufferedInputStream/BufferedOutputStream
                 为I/O提供了带缓冲区的操作,这种流模式提高了I/O的性能     
                 .write();
                 .flush();//刷新缓冲区,否则写入不到文件中
                 .close();
 
五、字符流(参考API)
       1、Java为什么引入字符流?
             操作文本时,尤其是包含中文字符等非ASCII码的字符会很不方便
             字符流 = 字节流+编码
             所以,要对编码问题非常清楚   
       2、java的文本(char)是16位无符号整数,是字符的Unicode编码(双字节)    
          文件是byte byte byte……的数据序列
          文本文件是文本序列按照某种编码方式序列化为byte的存储
       3、字符流(Reader Writer)操作的是文本文件
          一次处理一个字符,字符的底层仍然是基本的字节序列
          InputStreamReader 完成byte流按照编码解析为char流
          OutputStreamWriter 提供char流按照编码解析成byte流
       4、文件读写流  FileReader、FileWriter
             没法设置编码,必须回到字符流设置编码
       5、字符流的过滤器BufferedReader、BufferedWriter、PrintWriter
             readLine  可以一次读一行,一次写一行
             可以设置编码,不识别换行,单独写出换行操作
 
六、对象的序列化和反序列化
         1、将Object对象转换成byte序列,反之叫对象的反序列化
         2、序列化流(ObjectOutputStream),是过滤流---writeObject()
            反序列化流(ObjectInputStream),    ----readObject
         3、序列化接口(Serializable)
            对象必须实现序列化接口,才能进行序列化,否则将出现异常
            这个接口没有任何方法,只是一个标准,是标记接口
            
            对象序列化后,如果对再次对类文件修改,那么反序列化的时候就会出问题,那么怎么解决呢?
            需要在类中设置序列版本id,唯一标记,这样无论怎么修改读取的时候都不会再有问题   serialVersionUID
 
         4、transient关键字
               声明的元素不会进行JVM默认的序列化,也可以自己完成这个元素的序列化
               网络中传输时,并不是所有的元素都是有必要传输的,尤其是要考虑节约网络流量的时候
               在有些情况下,可以帮助我们提高性能(ArrayList在数组没有放满的时候,只把有效元素序列化)
         5、序列化中 子类和父类构造函数的调用问题
             父类实现了序列化接口,子类不需要再次实现,就能进行序列化    
             对子类对象进行反序列化操作时,如果其父类没有显示的实现序列化接口,那么其父类的构造函数会被调用
 
七、输入输出流的一些包装类
       1、打印流
               PrintStream  :字节打印流
               PrintWriter  :字符打印流
               集成了Print()格式化输出方法,可以操作任意类型的数据
       2、标准输入输出流
               System类的in、out字段
               默认输入设备是键盘,输出设备是显示器
               

               标准IO重定向
               System.setIn(InputStream);
               //重定向输出可以将打印到控制台的日志写到文件
               System.setOut(PrintStream);
               System.err(PrintStream);
 
       3、进程控制
              在Java内部执行其他操作系统的程序,并要求控制这些程序的输入输出时
              向OSExecute.command()传递一个command字符串   
Process process = new ProcessBuilder(command.split(" ")).start();

OSExecute.command("javap test");

//javap是java的一个反编译程序

八、IO操作过程中异常处理

        
       自己编程要用try-catch-finally包围起来,如果有异常尽量处理,千万不要仅仅是用printStackTrace()打印栈信息,在finally中进行流的关闭(判断引用不为空的话关闭),以确保一定能得到执行

Java-IO 输入输出流详解的更多相关文章

  1. Java IO 输入输出流 详解 (一)***

    首先看个图: 这是Javaio 比较基本的一些处理流,除此之外我们还会提到一些比较深入的基于io的处理类,比如console类,SteamTokenzier,Externalizable接口,Seri ...

  2. Java I/O输入输出流详解

    一.文件的编码               开发时一定要注意项目默认的编码!!!!!!!!               文件操作的时候一定要记得关闭!!!!!!!!        ASCII:美国标准 ...

  3. 转 Java输入输出流详解(非常详尽)

    转  http://blog.csdn.net/zsw12013/article/details/6534619 通过数据流.序列化和文件系统提供系统输入和输出. Java把这些不同来源和目标的数据都 ...

  4. Java输入输出流详解

    通过数据流.序列化和文件系统提供系统输入和输出. Java把这些不同来源和目标的数据都统一抽象为数据流.Java语言的输入输出功能是十分强大而灵活的,美中不足的是看上去输入输出的代码并不是很简洁,因为 ...

  5. JAVA之I/O 输入输出流详解

    简    介 如何在Java中进行文件的读写,Java IO流是必备的知识.这篇博文主要为您带来Java中的输入输出流的内容,包括文件编码.使用File类对文件和目录进行管理.字节流和字符流的基本操作 ...

  6. java.io.DataInput接口和java.io.DataOutput接口详解

    public interface DataInput DataInput 接口用于从二进制流中读取字节,并重构所有 Java 基本类型数据.同时还提供根据 UTF-8 修改版格式的数据重构 Strin ...

  7. java.IO输入输出流:过滤流:buffer流和data流

    java.io使用了适配器模式装饰模式等设计模式来解决字符流的套接和输入输出问题. 字节流只能一次处理一个字节,为了更方便的操作数据,便加入了套接流. 问题引入:缓冲流为什么比普通的文件字节流效率高? ...

  8. java.io.ObjectInputStream类详解

    1.public class ObjectInputStream extends InputStream implements ObjectInput, ObjectStreamConstants分析 ...

  9. JDK1.8 java.io.Serializable接口详解

    java.io.Serializable接口是一个标志性接口,在接口内部没有定义任何属性与方法.只是用于标识此接口的实现类可以被序列化与反序列化.但是它的奥秘并非像它表现的这样简单.现在从以下几个问题 ...

随机推荐

  1. 【Winform】Winform 制作一键发布web

    前言 最近web网站有个需要,就是打包给客户,客户能够自己手动的进行傻瓜式的安装发布web.找了很多资料,其中涉及到 文件解压 IIS操作 数据库还原 等. 发现现在就主要是两种解决方案: ①:使用V ...

  2. SQL SERVER 设置自动备份和删除旧的数据库文件

    打开SQL SERVER MANAGEMENT STUDIO,启动SQL SERVER代理服务(注意在“控制面板-管理工具-服务”中设置SQL SERVER AGENT的启动类型为自动).启动后点击“ ...

  3. 框架使用的技术主要是SpringMVC 在此基础上进行扩展

    框架使用的技术主要是SpringMVC 在此基础上进行扩展 1 Web前端使用 2 前段控制器采用SpringMVC零配置 3 IOC容器Spring 4 ORM使用 Mybites或者hiberna ...

  4. Qt4.8.6+mingw+Qgis2.4.0基于QGis的二次开发

    关于QGis的二次开发,大致看了一下,基本都是在VC+QT的环境下做环境部署,并且QGis的版本号很老.在mingw下直接开发搭建好开发环境的样例少之又少.基于最新的Qgis2.4.0版本号做了对应的 ...

  5. #define使用方法

    1.简单的define定义 #define MAXTIME 1000 一个简单的MAXTIME就定义好了,它代表1000,假设在程序里面写 if(i<MAXTIME){.........} 编译 ...

  6. Spark wordcount 编译错误 -- reduceByKey is not a member of RDD

    Attempting to run http://spark.apache.org/docs/latest/quick-start.html#a-standalone-app-in-scala fro ...

  7. 奇异值分解(SVD) --- 几何意义

    原文:http://blog.sciencenet.cn/blog-696950-699432.html PS:一直以来对SVD分解似懂非懂,此文为译文,原文以细致的分析+大量的可视化图形演示了SVD ...

  8. php对象当参数传递 && php深复制和浅复制

    把对象当参数传递给方法,在方法里改过对象后,影响到外面的对象  因为对象是引用传递过去的 class Book { public $name; public function __construct( ...

  9. The First

    好吧,今天是第一次,写博客,虽然有点不明白,博客的作用.以后就写点感想,与每天的收获.既然,在博客园注册,自然也与IT相关了. hello,world!

  10. C笔记01:关于printf函数输出先后顺序的讲解

    关于printf函数输出先后顺序的讲解!! 对于printf函数printf("%d%d\n", a, b);函数的实际输出顺序是这样的先计算出b,然后再计算a,接着输出a,最后再 ...