时间:2021-05-20
首先要明确一下转换规则:大数转小数,多出的高位部分会被截断。比如 int 占 4个byte(32 bit), byte占 1个byte(8bit), 那int 转 byte ,int 高位多出的那24个bit会被截断。
例1:
int b = 233; // 正整数强转System.out.println((byte)b);// 原码: 0000 0000 0000 0000 0000 0000 1110 1001// 补码(内存):0000 0000 0000 0000 0000 0000 1110 1001 // 正数的原码、反码、补码都一样// 截取...// 补码(截取后-内存):1110 1001 // 最高位是 1,说明是负数,因此在显示的时候还需要做转化...// 反码: 1110 1000 // 原码: 1001 0111 // 16+4+2+1 = -23 (注意符号位是 1,是负数)例2:
int b = -233; // 负整数强转System.out.println((byte)b);// 原码: 1000 0000 0000 0000 0000 0000 1110 1001 // 因为是负数,所以符号位是 1 // 反码: 1111 1111 1111 1111 1111 1111 0001 0110 // 负数的反码,符号位不变,其它位取反// 补码(内存): 1111 1111 1111 1111 1111 1111 0001 0111 // 负数的补码等于它的反码 + 1 // 截取...// 补码(截取后-内存):0001 0111 // 最高位是0,说明是正数,正数的原码、反码、补码都一样 // 原码: 0001 0111 // 16+4+2+1 = 23Note:
1. 数字在内存中进行计算的时候始终是以补码的形式进行的,但是显示给我们用户看的时候却是以原码的形式展示的,因此在运算之前必须先转换成补码的形式。
2. int 转 byte, 截断的是高位的24个bit, int 转 short, 截断的则是高位的16个bit,依此类推。
声明:本页内容来源网络,仅供用户参考;我单位不保证亦不表示资料全面及准确无误,也不保证亦不表示这些资料为最新信息,如因任何原因,本网内容或者用户因倚赖本网内容造成任何损失或损害,我单位将不会负任何法律责任。如涉及版权问题,请提交至online#300.cn邮箱联系删除。
一、JavaScript基本语法。(一)数据类型与变量类型。整数,小数,布局,字符串,日期时间,数组强制转换:parseInt()parseFloat()isN
Java多态对象的类型转换这里所说的对象类型转换,是指存在继承关系的对象,不是任意类型的对象。当对不存在继承关系的对象进行强制类型转换时,java运行时将抛出j
在Java中,基本类型之间的强制转换也不是这样的,比如,整数要转换成字符串,必须使用Integer.toString()静态方法或者String.valueOf
GO语言的float64类型在做加减乘除时会出现一些问题比如乘法运算,实例,将小数的元转换成整数的分:发现将小数的元乘以100后强制转换为整数分,少了1分解决办
java中,char类型变量可以强制转化为int类型变量,int类型变量也可以强制转化成char类型的变量:charc='a';inti=98;System.o