国内十大网站建设公司,玉树市wap网站建设公司,温州网上商城网站建设,wordpress 多站点 子目录匿名用户1级2016-08-29 回答转型被用来将一个数值从一种类型转换到另一种类型。下面的程序连续使用了三个转型。那么它到底会打印出什么呢#xff1f;public class Multicast{public static void main (String[] args){System.out.println((int)(char)(byte) -1);}}无论你怎样…匿名用户1级2016-08-29 回答转型被用来将一个数值从一种类型转换到另一种类型。下面的程序连续使用了三个转型。那么它到底会打印出什么呢public class Multicast{public static void main (String[] args){System.out.println((int)(char)(byte) -1);}}无论你怎样分析这个程序都会感到很迷惑。它以int数值-1开始然后从int转型为byte之后转型为char最后转型回int。第一个转型将数值从32位窄化到了8位第二个转型将数值从8位拓宽到了16位最后一个转型又将数值从16位拓宽回了32位。这个数值最终是回到了起点吗如果你运行该程序你就会发现不是。它打印出来的是65535但是这是为什么呢该程序的行为紧密依赖于转型的符号扩展行为。Java使用了基于2的补码的二进制运算因此int类型的数值-1的所有32位都是置位的。从int到byte的转型是很简单的它执行了一个窄化原始类型转化(narrowing primitive conversion)直接将除低8位之外的所有位全部砍掉。这样做留下的是一个8位都被置位了的byte它仍旧表示-1。从byte到char的转型稍微麻烦一点因为byte是一个有符号类型而char是一个无符号类型。在将一个整数类型转换成另一个宽度更宽的整数类型时通常是可以保持其数值的但是却不可能将一个负的byte数值表示成一个char。因此从byte到char的转换被认为不是一个拓宽原始类型的转换而是一个拓宽并窄化原始类型的转换(widening and narrowing primitive conversion)byte被转换成了int而这个int又被转换成了char。所有这些听起来有点复杂幸运的是有一条很简单的规则能够描述从较窄的整型转换成较宽的整型时的符号扩展行为如果最初的数值类型是有符号的那么就执行符号扩展如果它是char那么不管它将要被转换成什么类型都执行零扩展。了解这条规则可以使我们很容易地解决这个谜题。因为byte是一个有符号的类型所以在将byte数值-1转换成char时会发生符号扩展。作为结果的char数值的16个位就都被置位了因此它等于216-1即65535。从char到int的转型也是一个拓宽原始类型转换所以这条规则告诉我们它将执行零扩展而不是符号扩展。作为结果的int数值也就成了65535这正是程序打印出的结果。尽管这条简单的规则描述了在有符号和无符号整型之间进行拓宽原始类型时的符号扩展行为你最好还是不要编写出依赖于它的程序。如果你正在执行一个转型到char或从char转型的拓宽原始类型转换并且这个char是仅有的无符号整型那么你最好将你的意图明确地表达出来。如果你在将一个char数值c转型为一个宽度更宽的类型并且你不希望有符号扩展那么为清晰表达意图可以考虑使用一个位掩码即使它并不是必需的int i c 0xffff;或者书写一句注释来描述转换的行为int i c; //不会执行符号扩展如果你在将一个char数值c转型为一个宽度更宽的整型并且你希望有符号扩展那么就先将char转型为一个short它与char具有同样的宽度但是它是有符号的。在给出了这种细微的代码之后你应该也为它书写一句注释int i (short) c; //转型将引起符号扩展如果你在将一个byte数值b转型为一个char并且你不希望有符号扩展那么你必须使用一个位掩码来限制它。这是一种通用做法所以不需要任何注释char c (char) (b 0xff);