8位整型向16位,32位整型向64位转换会丢失数据吗?

小丑要睡了 2014-07-02 10:11:50
在不同的机器上,负数最高位补符号位时会变成正数,而出现丢失数据的情况吗?


int t1 = -1;
_int64 t2 = t1;

char c1 = -1;
short int si1 = c1;

printf("%d %I64d\n", t1, t2);
printf("%d %d", c1, si1);


以上代码,在不同机器上执行,就是两种会对符号位进行不同处理的机器,一种是高位符号扩展,另一种是高位补0,会出现不同的结果吗?

PS:不知哪里概念理解是不是有误。
...全文
422 4 打赏 收藏 转发到动态 举报
写回复
用AI写文章
4 条回复
切换为时间正序
请发表友善的回复…
发表回复
threenewbee 2014-07-03
  • 打赏
  • 举报
回复
什么叫“不同的机器”,在不同的机器上,相同的程序不可能都能运行。肯定需要编译器为不同的机器分别编译才行。
nice_cxf 2014-07-03
  • 打赏
  • 举报
回复
都是一样的,如果是gcc和vs,其他编译器就不清楚了,实际是否相同要看char是跟signed char还是unsigned char,常用的编译器都是char和signed char含义相同,那么结果必然相同
小丑要睡了 2014-07-02
  • 打赏
  • 举报
回复
引用 1 楼 taodm 的回复:
你要搞清楚,char不是8位整形。char就是char。 signed char、unsigned char才是8位整形。
不用纠结于这个地方,这不是重点
taodm 2014-07-02
  • 打赏
  • 举报
回复
你要搞清楚,char不是8位整形。char就是char。 signed char、unsigned char才是8位整形。
Java的 的8⼤基本数据类型 ⼤基本数据类型 Java8⼤基本数据类型 ⼤基本数据类型   byte(字节型)、short(短整型)、int (整型) 、long(长整型)   float(单精度浮点型)、double(双精度浮点型)、boolean(布尔型)、char(字符型) 整型   byte数据类型是8, 1个字节,默认值:0,取值范围:(-128 - 127);   short数据类型是16,两个字节,默认值:0,取值范围:(-2^15 - 2^15 -1);   int 数据类型是32,4个字节,默认值:0,取值范围:(-2^31 - 2^31 -1)   long数据类型是64,⼋个字节,默认值:0L,整型常量若要声明为long类型,需要在数字后加上l或L,long a = 10000L; 浮点型   float数据类型是单精度、32浮点数;默认值:0.0f,若要定义float类型的变量需要在⼩数后⾯追加f或者F,float a= 2.3f;   double数据类型是双精度、64、符合IEEE 754标准的浮点数;默认值:0.0d,double d = 2.3;   描述整数默认⽤int,描述⼩数默认⽤double。long⼀般⽤于描述⽇期、时间、内存、⽂件⼤⼩,IO处理⼀般使⽤byte 字符型   char⼀般⽤于描述中⽂(基本忽略),取值范围:(\u0000 - \uffff) —>(0 - 65535);,字符型⽤' '表⽰;char ch = 'A',   char和int可以相互转换,char转int直接赋值,int 转char强转。 布尔型   boolean表⽰⼀的信息,只有两个取值:true和false,默认值:false 每个数据类型对应的包装类中都有对应的SIZE属性返回数,MIN_VALUE和MAX_VALUE返回该数据类型最⼩值和最⼤值。 public class PrimitiveTypeTest{ public static void main(String[] args){ //byte System.out.println("基本类型:byte ⼆进制数:" + Byte.SIZE); System.out.println("包装类:java.lang.Byte"); System.out.println("最⼩值:Byte.MIN_VALUE = " + Byte.MIN_VALUE); System.out.println("最⼤值: Byte.MAX_VALUE = " + Byte.MAX_VALUE); // char System.out.println("基本类型:char ⼆进制数:" + Character.SIZE); System.out.println("包装类:java.lang.Character"); // 以数值形式⽽不是字符形式将Character.MIN_VALUE输出到控制台 System.out.println("最⼩值:Character.MIN_VALUE=" +(int)Character.MIN_VALUE); // 以数值形式⽽不是字符形式将Character.MAX_VALUE输出到控制台 System.out.println("最⼤值:Character.MAX_VALUE="+(int) Character.MAX_VALUE); } } 运⾏结果: 基本类型:byte ⼆进制数:8 包装类:java.lang.Byte 最⼩值:Byte.MIN_VALUE = -128 最⼤值: Byte.MAX_VALUE = 127 基本类型:char ⼆进制数:16 包装类:java.lang.Character 最⼩值:Character.MIN_VALUE=0 最⼤值:Character.MAX_VALUE=65535 Float和Double的最⼩值和最⼤值都是以科学计数法的形式输出的,结尾的"E + 数字"表⽰E之前的数字要乘以10的多少次⽅。 eg:1.4E-45 —> 1.4 10^(-45) 数据类型转换必须满⾜如下规则: 数据类型转换必须满⾜如下规则:   1.不能对boolean类型进⾏类型转换   2.不能把对象类型转换成不相关类的对象   3.⼩的数据类型与⼤的数据类型做数值运算时,⼩的数据类型⾃动提升为⼤的数据类型。   4.⼤的数据类型要转为⼩的数据类型必须强转,强转可能丢失数据。   5.浮点数到整数的转换是通过舍弃⼩数得到,⽽不是四舍五⼊   低级--------> ⾼级   byte,short,char->int->long->float->double 举例说明: p

64,691

社区成员

发帖
与我相关
我的任务
社区描述
C++ 语言相关问题讨论,技术干货分享,前沿动态等
c++ 技术论坛(原bbs)
社区管理员
  • C++ 语言社区
  • encoderlee
  • paschen
加入社区
  • 近7日
  • 近30日
  • 至今
社区公告
  1. 请不要发布与C++技术无关的贴子
  2. 请不要发布与技术无关的招聘、广告的帖子
  3. 请尽可能的描述清楚你的问题,如果涉及到代码请尽可能的格式化一下

试试用AI创作助手写篇文章吧