A股上市公司传智教育(股票代码 003032)旗下技术交流社区北京昌平校区

 找回密码
 加入黑马

QQ登录

只需一步,快速开始

© 郝锡强 黑马帝   /  2011-12-13 09:37  /  3440 人查看  /  5 人回复  /   0 人收藏 转载请遵从CC协议 禁止商业使用本文

本帖最后由 晨曦 于 2011-12-13 10:39 编辑

昨晚突然想到这样一个问题,比如int强制转换为byte,会精度丢失,如果byte强制转换为int可能会报错,
那么如何可以使低精度的转化为高精度的时候不报错呢
或者说能不能让低精度转换为高精度的时候,自动给用不到的内存赋值为0啊


就是说低精度转高精度的时候是自动补0的?
那高精度转低精度,不考虑丢失,在内存中就是直接取低8位了?
或者说,当高精度中的值不大于低精度取值范围,强制转换无论从低到高还是从高到低都不会出错吧

评分

参与人数 1技术分 +1 收起 理由
王德云 + 1 加油!!!

查看全部评分

5 个回复

正序浏览
冯敏 黑马帝 2011-12-13 10:41:12
地板
如果低精度向高精度转换的时候不会报错,编译器会自动向上转
byte->short->int->long
高精度向低精度转换,就要用到强制类型转换了,如果不转换,编译器会提示你损失精度

评分

参与人数 1技术分 +1 收起 理由
admin + 1

查看全部评分

回复 使用道具 举报
t_mac 黑马帝 2011-12-13 10:30:21
报纸
本帖最后由 t_mac 于 2011-12-13 10:39 编辑

楼上说的都对,初学者都容易犯这方面的错
我再补充一些,看完这些你就应该更加明白了,讲的还算详细的。

自动类型转换,也称隐式类型转换,是指不需要书写代码,由系统自动完成的类型转换。由于实际开发中这样的类型转换很多,所以Java语言在设计时,没有为该操作设计语法,而是由JVM自动完成。
转换规则

从存储范围小的类型到存储范围大的类型。
具体规则为:
byte→short(char)→int→long→float→double
也就是说byte类型的变量可以自动转换为short类型,示例代码:
byte b = 10;

short sh = b;

这里在赋值时,JVM首先将b的值转换为short类型,然后再赋值给sh。

在类型转换时可以跳跃。示例代码:

byte b1 = 100;

int n = b1;

注意问题

在整数之间进行类型转换时,数值不发生改变,而,特将整数类型别是比较大的整数类型转换成小数类型时,由于存储方式不同,有可能存在数据精度的损失。

强制类型转换,也称显式类型转换,是指必须书写代码才能完成的类型转换。该类类型转换很可能存在精度的损失,所以必须书写相应的代码,并且能够忍受该种损失时才进行该类型的转换。

转换规则

从存储范围大的类型到存储范围小的类型。

具体规则为:

double→float→long→int→short(char)→byte

语法格式为:

(转换到的类型)需要转换的值

示例代码:

double d = 3.10;

int n = (int)d;

这里将double类型的变量d强制转换成int类型,然后赋值给变量n。需要说明的是小数强制转换为整数,采用的是“去1法”,也就是无条件的舍弃小数点的所有数字,则以上转换出的结果是3。整数强制转换为整数时取数字的低位,例如int类型的变量转换为byte类型时,则只去int类型的低8位(也就是最后一个字节)的值。

评分

参与人数 1技术分 +2 收起 理由
admin + 2

查看全部评分

回复 使用道具 举报
谁说自动转化为高精度的时候会出错.不会出错啊!
低精度转换为高精度的时候,高位本来就是自动补0或补1的

评分

参与人数 1技术分 +1 收起 理由
admin + 1

查看全部评分

回复 使用道具 举报
低精度转化成高精度怎么会报错呢?就好像毕老师说的,低精度相当于一个小碗,高精度相当于一个大碗,大碗的水强制往小碗倒,那么水会溢出来。小碗的水往大碗倒时肯定能装下啊。

评分

参与人数 1技术分 +1 收起 理由
admin + 1

查看全部评分

回复 使用道具 举报
byte转为int,int转为long,都不会报错(刚才还验证了一下)
回复 使用道具 举报
您需要登录后才可以回帖 登录 | 加入黑马