zoukankan      html  css  js  c++  java
  • java中字节数组和字符串、IO流和字节数组之间的转换

    在实际开发中经常会碰到乱码问题:

    首先查看系统支持的编码方式,默认的编码方式

        //检查java支持的编码
            System.out.println(Charset.availableCharsets().toString());
            //检查系统默认的编码方式
            System.out.println(Charset.defaultCharset());
            //检查某种编码方式系统是否支持
            System.out.println(Charset.isSupported("GBK"));


    根据打印的结果,android默认支持的编码方式为UTF-8

    字节数组——>字符串

    public String bytes2String(byte[] bytes,String charsetName){
            try {
                //如果不指定charsetName,直接new String(bytes)默认使用utf-8
                return (new String(bytes,charsetName));
            } catch (UnsupportedEncodingException e) {
                e.printStackTrace();
                return null;
            }
        }

    字符串——>字节数组

    public byte[] string2bytes(String str,String charsetName){
            //同样,如果不指定编码集的话就是用默认编码
            try {
                return str.getBytes(charsetName);
            } catch (UnsupportedEncodingException e) {
                e.printStackTrace();
                return null;
            }
        }

    在android中字节数组和字符串之间的转换还可以借助EncodingUtils这个类

    getBytes(String data, String charset)

    getString(byte[] data, String charset)

    InputStream——>byte[]

        public byte[] inputStream2Bytes(InputStream inStream) {
            ByteArrayOutputStream swapStream = new ByteArrayOutputStream();
            byte[] buff = new byte[100];
            int rc = 0;
            try {
                while ((rc = inStream.read(buff, 0, 100)) > 0) {
                    swapStream.write(buff, 0, rc);
                }
                return swapStream.toByteArray();
            } catch (IOException e) {
                e.printStackTrace();
                return null;
            }
        }

    byte[]——>inputstream

    public InputStream byte2InputStream(byte[] bytes){
            return new ByteArrayInputStream(bytes);
        }

    关于java的io流的一些说明:
    输入流:只能够读取(将物理节点的值读取到内存的byte[]数组等)如fileInputstream.read(buffer);是将物理文件中的数据读取到buffer中

    方向是物理节点——>buffer

    输出流:将具体的数值写入(文件或其他)输出流 。如fileOutputStream.write(“我是测试数据”);方向是buffer/string——>物理节点

    一、字节流和字符流

    java的io分为两大类,字节流和字符流。可以认为能够用写字板打开的文本文件为字符。

     字节流:以inputstream,outputstream为基类

    字符流:以reader、writer为基类

    一般,如果操作的是文本文件,可以直接使用字符流

    二、节点流和包装流

    节点流:如果(输入流)构造函数中传递的是具体的物理节点,那么是节点流。如

    byteArrayInputStream(byte[] ),byteArrayOutputStream()

    FileInputStream(File );FileOutputStream(File file,booolean append);后一个参数指定是覆盖还是添加

    如果文件名不存在,但是上一级的目录存在,FileInputStream构造函数会自动创建新文件,否则,需要首先使用makeDirs将目录创建出来

    以及与之对应的字符流

    CharArrayReader,CharArrayWriter

    FileReader,FileWriter

    包装流:构造函数中的参数为节点流的流

    如缓冲流:BufferedInputStream(InputStream in)BufferedOutputStream(OutputStream out);其对应的字符流为:

    BufferedReader(Reader in);该类有一个readline方法,可以方便地读取文本文件中的一行。BufferedWriter(Writer out)

    使用缓冲流可以提高输入输出的效率,

    又如对象流:ObjectInputStream(InputStream input),ObjectOutputStream(OutputStream output) 分别拥有readObject和writeObject方法,可以用于对象的序列化

    又比如转换流,也可以看作是包装流。

    InputStreamReader(InputStream in, String charsetName);构造函数中可以指定编码。若不指定采用默认编码

    OutputStreamWriter(OutputStream out, String charsetName)

    这两个流将字节流转换为字符流,方便文本文件的处理,并且由于可以指定编码,在解决乱码中可以很方便的采用。

    比如,读取一个文本文件中的内容,就可以这样包装

    FileInputStream——>InputStreamReader——>BufferedReader

    当然,也可以有其他方法

  • 相关阅读:
    Windows Server 2008 IIS7.0 发布html和Asp.net网站
    GS+9.0地统计软件学习
    将Mxd文件压缩并上传到Geodatabase!
    Git代码版本管理
    一台机器,两个Oracle数据库,两个SDE服务!
    翻译:A Picturebox Control to Display Both Remote Sensing and Regular Digital Images
    ENVI处理Modis数据学习
    C#开源资源
    winform中ToString()、DateTime.ToString()、DateTime
    加速Vs2008
  • 原文地址:https://www.cnblogs.com/bobodeboke/p/3071753.html
Copyright © 2011-2022 走看看