toString()、new String()和(String) 、String.ValueOf()的区别
先来看段代码:
String str="hello";
String base64Encoded=Hex.encodeToString(str.getBytes());
String str2=new String(Hex.decode(base64Encoded));
String str3=(Hex.decode(base64Encoded)).toString(); //str3的值为[[email protected]
System.out.println(str2.equals(str));
System.out.println(str3.equals(str));
第一个输出结果为true,第二个输出结果为false这是为什么呢?
原来,toString()方法是调用了这个object对象的toString方法。一般是返回这么一个String:[class name]@[hashCode],即对象在内存中的地址。在这种使用方法中,因为java.lang.Object类里已有public方法.toString(),所以对任何严格意义上的java对象都可以调用此方法。但在使用时要注意,必须保证object不是null值,否则将抛出NullPointerException异常。采用这种方法时,通常派生类会覆盖Object里的toString()方法。
而new String(b)是根据parameter是一个字节数组,使用java虚拟机默认的编码格式,将这个字节数组decode为对应的字符。若虚拟机默认的编码格式是ISO-8859-1,按照ascii编码表即可得到字节对应的字符。所以new String()方法返回的才是真实的值
再来看(String)
Object obj = new Integer(100);
String strVal = (String)obj;
在运行时将会出错,因为将Integer类型强制转换为String类型,无法通过。如下图:
这是因为,这种标准的类型转换,将object转成String类型的值。使用这种方法时,需要注意的是类型必须能转成String类型。因此最好先用instanceof做个类型检查,以判断是否可以转换。否则容易抛出ClassCastException异常。此外,需特别小心的是因定义为Object 类型的对象在转成String时语法检查并不会报错,这将可能导致潜在的错误存在。这时要格外小心。
最后再来看String.valueOf()
这个方法是静态的,直接通过String调用,可以说是完美,只是平时使用不多,这样的实现避免了前面两个的不足和缺点。首先来看看他内部的实现机制:
public static String valueOf(Object obj){
return (obj==null) ? "null" : obj.toString()
};
从这可以看出,其在内部就是作了为空的判断的,所以就不会报出空指针异常。
但我们也要很清醒地认识到,当object为null 时,String.valueOf(object)的值是字符串”null”,而不是null!!!在使用过程中切记要注意。我们可以使用以下代码进行检验:
Object obj = null;
System.out.println(String.valueOf(obj) + "->此处null的类型是" + String.valueOf(obj).getClass());
System.out.println(obj);
我们看到的输出将是一模一样的东西:null,但它们意义其实并不相同。
推荐阅读
-
string,stringbuffer和stringbuilder的区别详解
-
String、StringBuffer和StringBuilder的区别
-
String、StringBuffer和StringBuilder的区别
-
toString()、new String()和(String) 、String.ValueOf()的区别
-
String和StringBuilder、StringBuffer的区别?
-
string.valueof和toString的区别
-
String, toString(), String.valueOf()的区别
-
String toString() String.valueOf()的区别
-
Java 中String和StringBuffer的区别
-
字符数组和字符串,char 和string定义的字符串的区别与遍历