转自:re硕君
public
static
void
main(String[] args) {
String str =
"123.56"
;
Double d =
123.56
;
BigDecimal b1 =
new
BigDecimal(str);
//输出123.56
BigDecimal b2 =
new
BigDecimal(d);
//输出123.56000000000000227373675443232059478759765625
//b2 直接使用double 转成BigDecimal对象
BigDecimal b3 =
new
BigDecimal(Double.toString(d));
//输出123.56
System.out.println(b1);
System.out.println(b2);
System.out.println(b3);
一、由基本数据型态转换成String
String 类别中已经提供了将基本数据型态转换成 String 的 static 方法 ,也就是 String.valueOf() 这个参数多载的方法
有以下几种
(1)String.valueOf(boolean b) : 将 boolean 变量 b 转换成字符串
(2)String.valueOf(char c) : 将 char 变量 c 转换成字符串
(3)String.valueOf(char[] data) : 将 char 数组 data 转换成字符串
(4)String.valueOf(char[] data, int offset, int count) : 将 char 数组 data 中 由 data[offset] 开始取 count 个元素 转换成字符串
(5)String.valueOf(double d) : 将 double 变量 d 转换成字符串
(6)String.valueOf(float f) : 将 float 变量 f 转换成字符串
(7)String.valueOf(int i) : 将 int 变量 i 转换成字符串
(8)String.valueOf(long l) : 将 long 变量 l 转换成字符串
(9)String.valueOf(Object obj) : 将 obj 对象转换成 字符串, 等于 obj.toString()
用法如下:
int i = 10;
String str = String.valueOf(i);
这时候 str 就会是 "10"
二、由 String 转换成 数字的基本数据型态
要将 String 转换成基本数据型态转 ,大多需要使用基本数据型态的包装类别
比如说 String 转换成 byte ,可以使用 Byte.parseByte(String s) ,这一类的方法如果无法将 s 分析 则会丢出 NumberFormatException
(1)byte : Byte.parseByte(String s) : 将 s 转换成 byte
(2)Byte.parseByte(String s, int radix) : 以 radix 为基底 将 s 转换为 byte ,比如说 Byte.parseByte("11", 16) 会得到 17
(3)double : Double.parseDouble(String s) : 将 s 转换成 double
(4)float : Double.parseFloat(String s) : 将 s 转换成 float
(5)int : Integer.parseInt(String s) : 将 s 转换成 int
(6)long : Long.parseLong(String s)
补充知识:Java常用之String.valueOf、toString、(String)
字符串类型的转型在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有以下几种重载:
b9f41410a774e9238570e5e4954de018.png
在代码中写下如下:
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的。在使用时需要注意。
————————————————
原文链接:https://blog.csdn.net/weixin_34792641/article/details/114063972
String 类别中已经提供了将基本数据型态转换成 String 的 static 方法 ,也就是 String.valueOf() 这个参数多载的方法
有以下几种
(1)String.valueOf(boolean b) : 将 boolean 变量 b 转换成字符串
(2)String.valueOf(char c) : 将 char 变量 c 转换成字符串
(3)String.valueOf(char[] data) : 将 char 数组 data 转换成字符串
(4)String.valueOf(char[] data, int offset, int count) : 将 char 数组 data 中 由 data[offset] 开始取 count 个元素 转换成字符串
(5)String.valueOf(double d) : 将 double 变量 d 转换成字符串
(6)String.valueOf(float f) : 将 float 变量 f 转换成字符串
(7)String.valueOf(int i) : 将 int 变量 i 转换成字符串
(8)String.valueOf(long l) : 将 long 变量 l 转换成字符串
(9)String.valueOf(Object obj) : 将 obj 对象转换成 字符串, 等于 obj.toString()
用法如下:
int i = 10;
String str = String.valueOf(i);
这时候 str 就会是 "10"
二、由 String 转换成 数字的基本数据型态
要将 String 转换成基本数据型态转 ,大多需要使用基本数据型态的包装类别
比如说 String 转换成 byte ,可以使用 Byte.parseByte(String s) ,这一类的方法如果无法将 s 分析 则会丢出 NumberFormatException
(1)byte : Byte.parseByte(String s) : 将 s 转换成 byte
(2)Byte.parseByte(String s, int radix) : 以 radix 为基底 将 s 转换为 byte ,比如说 Byte.parseByte("11", 16) 会得到 17
(3)double : Double.parseDouble(String s) : 将 s 转换成 double
(4)float : Double.parseFloat(String s) : 将 s 转换成 float
(5)int : Integer.parseInt(String s) : 将 s 转换成 int
(6)long : Long.parseLong(String s)
补充知识:Java常用之String.valueOf、toString、(String)
字符串类型的转型在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有以下几种重载:
b9f41410a774e9238570e5e4954de018.png
在代码中写下如下:
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的。在使用时需要注意。
————————————————
原文链接:https://blog.csdn.net/weixin_34792641/article/details/114063972