字符串类型的转型在java中常用的方法有标题中的三种。
简单介绍:
1、toString,需要保证调用这个方法的类、方法、变量不为null,否则会报空指针。
2、String.valueOf。这个方法在使用的时候是有些特殊的。一般情况下,如果是确定类型的null传入,返回的是字符串“null”,而如果直接传入null,则会发生错误。
3、(String) 字符串类型强转。需要保证的是类型可以转成String类型。
这里重点介绍valueOf。
举个例子:
String teString=null; teString=String.valueOf(teString); System.out.println(teString);
这样的写法,因为确定了传入的是String类型,在valueOf调用对应构造函数时不会发生错误,因此,返回的是字符串“null”。
String.valueOf(null);
但如果改为以上的写法,则提示空指针。
问题分析:为何会出现以上两种不同的结果,看源码我们即可知道原因。
valueOf有以下几种重载:
在代码中写下如下:
boolean temp = false; String.valueOf(temp); char temp1 = 0; String.valueOf(temp1); double value = 0; String.valueOf(value); Object object=null; String.valueOf(object); float f = 0; String.valueOf(f); int i = 0; String.valueOf(i); long l = 0; String.valueOf(l); System.out.println("------------分割线---------------"); //导致空指针 char[] chars=null; String.valueOf(chars); //导致空指针 String.valueOf(null, 0, 0);
运行后,可看到导致空指针的只可能是后面的两种方式。源码中valueOf(char[])会最终走到valueOf(char[],int,int)这个重载中,因此我们直接看对应的源码,如下:
public String(char[] data, int offset, int charCount) { if ((offset | charCount) < 0 || charCount > data.length - offset) { throw failedBoundsCheck(data.length, offset, charCount); } this.offset = 0; this.value = new char[charCount]; this.count = charCount; System.arraycopy(data, offset, value, 0, count); }
这里将导致空指针。
知道了导致空指针的原因,还有一个疑惑,那就是为什么String.valueOf(null),会走到valueOf(char[])这个重载,而不是其他重载呢?
因为java中对重载的匹配是,当重载都能匹配的时候,优先选择范围小,精度高的方法,因此,它自动重载了char[]这个方法。
通过以上,发现String.valueOf()方法是有可能出现null的。在使用时需要注意。