java中的强制类型转换

Posted

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了java中的强制类型转换相关的知识,希望对你有一定的参考价值。

参考技术A

用(String)做强制类型转换和用String.valueOf()区别在于:

String 就是直接强制转化成String型的字符串,且有优先级限制,像int i=123;不能String s=(String)i。

而String.valueOf()里面的参数转换可以是double、long、char[] 、long等等,没限制,所以String s=String.valueOf(i)。

toString()方法返回的是这个对象的字符串表示,就像是这个对象的名字一样,任何对象都可以有自己的名字,你可以重写其toString()方法,给其赋予任意的名字。

但是调用toString()方法的对象不能为 null,否则会抛出异常:java.lang.NullPointerException。

例子如下:

扩展资料:

java中强制类型转换

在Java中强制类型转换分为基本数据类型和引用数据类型两种,这里我们讨论的后者,也就是引用数据类型的强制类型转换。

在Java中由于继承和向上转型,子类可以非常自然地转换成父类,但是父类转换成子类则需要强制转换。

因为子类拥有比父类更多的属性、更强的功能,所以父类转换为子类需要强制。那么,是不是只要是父类转换为子类就会成功呢?其实不然,他们之间的强制类型转换是有条件的。

当我们用一个类型的构造器构造出一个对象时,这个对象的类型就已经确定的,也就说它的本质是不会再发生变化了。

在Java中我们可以通过继承、向上转型的关系使用父类类型来引用它,这个时候我们是使用功能较弱的类型引用功能较强的对象,这是可行的。但是将功能较弱的类型强制转功能较强的对象时,就不一定可以行了。

举个例子来说明。比如系统中存在Father、Son两个对象。首先我们先构造一个Son对象,然后用一个Father类型变量引用它:

Father father = new Son();

在这里Son 对象实例被向上转型为father了,但是请注意这个Son对象实例在内存中的本质还是Son类型的,只不过它的能力临时被消弱了而已,如果我们想变强怎么办?将其对象类型还原!

Son son = (Son)father;

这条语句是可行的,其实father引用仍然是Father类型的,只不过是将它的能力加强了,将其加强后转交给son引用了,Son对象实例在son的变量的引用下,恢复真身,可以使用全部功能了。

前面提到父类强制转换成子类并不是总是成功,那么在什么情况下它会失效呢?

当引用类型的真实身份是父类本身的类型时,强制类型转换就会产生错误。例如:

Father father = new Father();

Son son = (Son) father;

这个系统会抛出ClassCastException异常信息。

所以编译器在编译时只会检查类型之间是否存在继承关系,有则通过;而在运行时就会检查它的真实类型,是则通过,否则抛出ClassCastException异常。

所以在继承中,子类可以自动转型为父类,但是父类强制转换为子类时只有当引用类型真正的身份为子类时才会强制转换成功,否则失败

java 类型转换 String转BigInteger

if(list.size()>0)

//------------增加一行并计算合计数 begin
RptErrorStatForView rws= new RptErrorStatForView();
rws.setTradeDate("合计");
BigInteger tradeTotalCount = BigInteger.ZERO;
BigInteger errorLev1Count = BigInteger.ZERO;
// BigInteger errorLev1Rate = BigInteger.ZERO;
BigInteger errorLev2Count = BigInteger.ZERO;
// BigInteger errorLev2Rate = BigInteger.ZERO;
BigInteger errorLev3Count = BigInteger.ZERO;
// BigInteger errorLev3Rate = BigInteger.ZERO;

for(int i = 0; i < li.size(); i++)

//String 转 BigInetger 类型! 没查到 需提问
RptErrorStatForView stat = li.get(i);

tradeTotalCount = tradeTotalCount.add(stat.getTradeTotalCount());
errorLev1Count = errorLev1Count.add(stat.getErrorLev1Count());
//此处stat.getErrorLev1Count()获取的是BigInteger类型

// errorLev1Rate = errorLev1Rate.add(stat.getErrorLev1Rate());
//此处stat.getErrorLev1Rate() 获取的是String类型 问题就在此处,
//String类型不能进行add,需要转换成BigInteger类型,先不考虑精度, 怎么才能转换,麻烦点没关系,能转换就成。
求赐教!!~~

errorLev2Count = errorLev2Count.add(stat.getErrorLev2Count());
// errorLev2Rate = errorLev2Rate.add(new BigInteger(stat.getErrorLev2Rate()));
errorLev3Count = errorLev3Count.add(stat.getErrorLev3Count());
// errorLev3Rate = errorLev3Rate.add(new BigInteger(stat.getErrorLev3Rate()));
//

rws.setTradeTotalCount(tradeTotalCount);
rws.setErrorLev1Count(errorLev1Count);
// rws.setErrorLev1Rate(formatStr(String.valueOf(errorLev1Rate)));
rws.setErrorLev2Count(errorLev2Count);
// rws.setErrorLev2Rate(formatStr(String.valueOf(errorLev2Rate)));
rws.setErrorLev3Count(errorLev3Count);
// rws.setErrorLev3Rate(formatStr(String.valueOf(errorLev3Rate)));
li.add(rws);
// ------------增加一行并计算合计数 end

return new Page(li.size(),li);

TO christal_yhy :
new BigInteger(字符串,精度)
我试过 errorLev2Rate = errorLev2Rate.add(new BigInteger(stat.getErrorLev2Rate()));
后台报错! 错误指向 errorLev2Rate = errorLev2Rate.add(new BigInteger(stat.getErrorLev2Rate()));

to all: 如果是小数比如:“0.1” 能转换成biginteger类型吗?

楼主理解错了,难怪你会报错,new BigInteger(String,int)是转换字符串的表达式为指定(radix)进制的大整数,进制,也就是十进制,十六进制等,BigInteger sixthtest = new BigInteger("FF",16);
System.out.println("sixthtest"+sixthtest);
输出结果是sixthtest255
建议楼主看看这个,你就会知道了。http://hi.baidu.com/gengshenspirit/blog/item/a4cd8a5168ff36888c543004.html
我也学习了,以前没弄过。
参考技术A new BigInteger(字符串,精度)

以上是关于java中的强制类型转换的主要内容,如果未能解决你的问题,请参考以下文章

java中的Enum强制转换

java中的强制类型转换

java中的强制类型转换

C++中的数据类型强制转换

关于java中的short和int类型转换的问题

java中如何进行安全的类型转换