关于java输出流ByteArrayOutputStream的toString()方法

import java.io.*;

public class ByteArrayOutputStreamtoString {
public static void main(String[] args){
ByteArrayOutputStream baos = new ByteArrayOutputStream();
DataOutputStream dos = new DataOutputStream(baos);
try{
dos.writeBoolean(true);
dos.writeDouble(2.345456);
dos.writeFloat(1.234354f);
String s = baos.toString();
System.out.println(s);
}catch(IOException e){
e.printStackTrace();
}
}
}


他的输出为什么是“@�~oq��?��P”这样的乱码?,还有toString()这个方法的用法是什么?是用来干什么的呢?

不是这样用的 , ByteArrayOutputStream 存的是字节数组, toString 只是简单的把里面的 byte数组转成了字符串。程序可不知道你要怎么解析 byte。
出现乱码很正常。 下面给你正确的用法

import java.io.ByteArrayOutputStream;
import java.io.DataOutputStream;
import java.io.IOException;

/**
 * Created by chenhong on 16/3/10.
 */
public class Main {

    public static void main(String[] args){

        ByteArrayOutputStream baos = new ByteArrayOutputStream();
        DataOutputStream dos = new DataOutputStream(baos);
        try{


            dos.writeBoolean(true);  //boolean 1位
            dos.writeInt(2); // int 32位   4字节
            dos.writeFloat(1.234354f); // float 32位   32字节

            byte[] bArray = baos.toByteArray();
            System.out.println("共"+bArray.length+"字节");
            for (int i = 0; i < bArray.length; ++i){
                    System.out.println(bArray[i]+" ");
            }



        }catch(IOException e){
            e.printStackTrace();
        }
    }
}


看一下源代码中是这样解释的:
public synchronized String toString() {
return new String(buf, 0, count);
}
使用默认的编码格式解码buf中的字节为一个字符串。

首先,输出乱码是因为这个类重写了父类的toString方法,本质将创建的是利用缓冲区内的数据创建了一个字符串返回了,java字符串默认的编码格式是UTF-8,所以将你的缓冲区内的数据编码返回String后出现了乱码问题。
其次,toString方法作用就是输出这个对象信息的,如果使用Object默认的方法输出这个对象的地址,所以我们如果要想看到有意义的输出信息,通常是需要自己重写这个方法的。它就是输出对象信息的。