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

 找回密码
 加入黑马

QQ登录

只需一步,快速开始

© 明锦添 中级黑马   /  2013-3-22 09:09  /  1105 人查看  /  2 人回复  /   0 人收藏 转载请遵从CC协议 禁止商业使用本文

本帖最后由 明锦添 于 2013-3-22 10:41 编辑

在java数据类型转换中有些是默认转换,有些则要强制转换;这是为什么呢?它们遵循了哪些原则呢?
public class  ZhuanHuan
{
    public static void main(String[]  agrs)
     {
           int a,b=332;
           float x, y=8.123f;
           char c1='k',c2;
           a=y;
           x=b;
           a=c1;
           c2=b;
     System.out.println(a+","+x+","+a+","+c2);
     }
}这些代码中有哪些语句是错的?它们之间的转换遵循什么原则?

评分

参与人数 1技术分 +3 收起 理由
滔哥 + 3 恭喜你中了随机奖励

查看全部评分

2 个回复

倒序浏览
刚刚百度了一下,下面的内容你看一下

自动类型转换,也称隐式类型转换,是指不需要书写代码,由系统自动完成的类型转换。由于实际开发中这样的类型转换很多,所以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;

l 注意问题

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

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

转换规则

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

具体规则为:

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位(也就是最后一个字节)的值。

不知道对你有没有懂,我大部分看懂了,正在看这个更全的文章
http://www.cnblogs.com/andy2005/archive/2006/07/24/458564.html
有疑问接着回帖交流啊~

评分

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

查看全部评分

回复 使用道具 举报
a=y;//float类型不可以赋给int类型
c2=b;//int不可以转换成char类型

类型之间尽量不要去冒险转换,对你真正编程的时候完全没有好处

评分

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

查看全部评分

回复 使用道具 举报
您需要登录后才可以回帖 登录 | 加入黑马