首页 > 编程语言 > 详细

黑马程序员——26,基本数据操作流,字节数组操作流,转换流,编码表

时间:2015-08-14 11:45:15      阅读:253      评论:0      收藏:0      [点我收藏+]

------<ahref="http://www.itheima.com" target="blank">Java培训、Android培训、iOS培训、.Net培训</a>、期待与您交流! -------

          

         黑马程序员——26,

DataInputStream,DataOutputStream,

ByteArrayInputStream,ByteArrayOutputStream,

InputStreamReader,OutputStreamWriter,编码表

 

/*

DataInputStream和DataOutputStream

可以更加操作基本数据类型的流

注意这里是Data不是Date!

*/

 
import java.io.*;
class  Ioliou31
{
         public  static void  main(String[] args)throws  IOException
         {
          UTFDemo() ;      
         //  method(); 
         }
         public  static void  method()  throws IOException
         {
           File  f=new   File("f:\\科学.txt");  //封装目的文件为对象
           FileOutputStream     fos=new  FileOutputStream(f);//关联目的文件的流
           DataOutputStream     dos=new  DataOutputStream(fos);
           //再用专门操作基本类型数据的流的构造函数接收
 
           //以下注意写入的格式
           //不同的写入格式是按照不同位数写入的
           dos.writeInt(56);
           dos.writeBoolean(false);
           dos.writeDouble(15.24);
     /*  */
           FileInputStream    fis=new  FileInputStream(f);
          DataInputStream  dis=new   DataInputStream (fis);      
           //读取的时候注意要按照顺序读取,以及读取的格式
           //不同的读取格式是按照不同的位数来读取的
           int    i   =dis.readInt();
           boolean  bo=dis.readBoolean();
           double   dou=dis.readDouble();
           soc(i+"---"+bo+"---"+dou);
           //特别注意:什么格式写入的就用什么格式读取出来
 
           dos.close();
           dis.close();             
         }
         public   static void  UTFDemo()  throws IOException
         {
           File   f=new   File("f:\\科学.txt");  //封装目的文件为对象
 
 
           FileOutputStream     fos=new  FileOutputStream(f);//关联目的文件的流
           DataOutputStream     dos=new  DataOutputStream(fos);
 
           dos.writeUTF("这是");//四个字节组成一个字符,一共八个字节
          
           FileInputStream    fis=new  FileInputStream(f);
           DataInputStream  dis=new   DataInputStream (fis);
           soc(dis.readUTF());
           //readUTF方法返回的是字符串,用什么格式写就要用什么格式读取
         }
         public  static void  soc(Object  obj)
         {
              System.out.println(obj);           
         }
}

————————分割线————————

 

/*

操作字节数组的流(内部封装长度可变的字节数组)

ByteArrayInputStream

ByteArrayOutputStream

直接把字节数组传给其ByteArrayInputStream的构造函数,

传进来的字节数组就是源

源设备:

    键盘System.in    硬盘FileStream    内存ArrayStream

目的设备

    控制台System.out   硬盘FileStream   内存ArrayStream

 

这两个流没有调用底层资源,不用关闭close

另外,还有ByteArrayReader和ByteArrayWriter用法也是和上面两者类似。

ByteArrayReader构造函数传入的是字符数组。

*/

 

import java.io.*;
 
class  Ioliou32
{
         public   static void main(String[] args) throws IOException
         {
                   ByteArrayInputStream   bais=new   ByteArrayInputStream("哦奥额".getBytes());
                   ByteArrayOutputStream   baos=new  ByteArrayOutputStream();
                   int  i=0;
                  while((i=bais.read())!=-1)
                  {
                       baos.write(i);       
                   }
                   File   f=new  File("f:\\可乐可乐.java");
                   FileOutputStream    fos=new FileOutputStream(f);
                   baos.writeTo(fos);    //直接写入字节输出流中    
                  
 
         }
         public static void  soc(Object  obj)
         {
            System.out.println(obj);        
         }
}

——————分割线——————

 

/*

转换流与编码表:

转换流InputStreamReader和OutputStreamWriter

编码表:

   ASCII美国标准信息交换码,用一个字节的7位表示

         ISO8859-1  欧洲码表,拉丁码表不识别中文字符,用一个字节8位表示

         GB2312  中国中文编码表

         GBK     中国中文编码表升级版,两个字节表示一个字符

         Unicode   国际标准码,java使用的编码表

         UTF-8     最多三个字节表示一个字符

*/

 

import java.io.*;
class  Ioliou33
{
         publicstatic void main(String[] args) throws IOException
         {
       // write();
          read();               
         }
         public  static void  write()  throws IOException
         {
                   File   f=new  File("f:\\楼宇.txt");
                   FileOutputStream   fos=new  FileOutputStream(f);
                   OutputStreamWriter   osw=new  OutputStreamWriter(fos,"UTF-8");//要加上编码表版本
                   osw.write("动手打人了"); 
                   osw.close();
       /*
                   虽然写入之后我们代开f:\\楼宇.java文件看到的依旧是字符,
                   但是本质上文件存储的是编码表上对应的数字,只不过按照指定编码表兑换成字符而已。
                   */    
         }
         public  static void  read()  throws IOException
         {
                   File   f=new  File("f:\\楼宇.txt");
                   FileInputStream   fis=new FileInputStream(f);
                   InputStreamReader   isr=new InputStreamReader(fis,"UTF-8");//编码表版本要对应上
                   /*
                   读取的时候也是按照存储的数字再按照指定的编码表找出对应的字符
                   */
                   char[]    ch=new  char[20];
                   int  i=0;
                      while ((i=isr.read(ch))!=-1)
                      {
                         soc(new  String(ch,0,i));       
                      }
     
                   isr.close();                      
         }
         public  static void  soc(Object  obj)
         {
             System.out.println(obj);    
         }
 
 
}

——————分割线——————

 

/*

编码与解码:

常用编码表gbk,utf-8,ISO8859-1

*/

import java.io.*;
import java.util.*;
class  Ioliou34
 
{
         public  static void  main(String[] args)throws  Exception
         {
 
                 method2();
         }
         public  static void  method()  throws Exception
         {
                   String   s="开始游戏";
                   byte[]  by=  s.getBytes("utf-8");//按照utf-8编码表进行编码
                   soc(Arrays.toString(by));
                   String     s2=new  String(by,"ISo8859-1");//按照ISo8859-1编码表进行解码
                  soc("s2="+s2);
                   //如果按照不同的编码表进行解码的话会导致错误结果
       //如果遇到这种情况就需要再一次进行编码解码
                   byte[]    by2=s2.getBytes("ISo8859-1");
                   String   s3=new String(by2,"utf-8");
                   soc("s3="+s3);                        
         }
         public  static void  method2()  throws Exception
         {
                   String   s="开始游戏";
                   byte[]  by=  s.getBytes("utf-8");//按照utf-8编码表进行编码
                   soc(Arrays.toString(by));
                   String   s2=new String(by,"gbk");
                   soc("s2="+s2);
                   //如果按照不同的编码表进行解码的话会导致错误结果
       //如果遇到这种情况就需要再一次进行编码解码
                   byte[]    by2= s2.getBytes("gbk");
                   soc(Arrays.toString(by2));
                   String    s3=new String(by2,"utf-8");
                   soc("s3="+s3);
                   /*
                   由于gbk和utf-8都是中文编码表,所以,此时的情况与method方法中的不同,
                   method方法中解码过程出错的是因为使用了IOS8895-1拉丁码表,里面不知别中文字符,
                   而这里method2的情况则是解码过程中使用了可以识别中文的gbk码表,
                   解码中遇到对不上号的字符就会去gbk码表的乱码区查找,接着再用gbk码表编码就
                   不是原来的号吗了,所以,这里method2方法的s3就会显示乱码,而method方法的s3则是显示正确。
 
 
       */
         }
         public  static void  soc(Object  obj)
         {
             System.out.println(obj);            
         }
}

——————————分割线——————

 

 

版权声明:本文为博主原创文章,未经博主允许不得转载。

黑马程序员——26,基本数据操作流,字节数组操作流,转换流,编码表

原文:http://blog.csdn.net/dangaodeaiyi/article/details/47658367

(0)
(0)
   
举报
评论 一句话评论(0
关于我们 - 联系我们 - 留言反馈 - 联系我们:wmxa8@hotmail.com
© 2014 bubuko.com 版权所有
打开技术之扣,分享程序人生!