好久的事了。想确认下。
mian函数以前都喜欢return 0或1,测试失败还是成功,有一次无意间返回了一次-1;
返现编译器的报告:
当时想了想,-1的补码不就是0xffffffff么,也没在意,觉得可能是直接输出的计算机存储的值。后来无聊。测试了一个结果
int nTest = 0xffffffff;
std::cout << nTest;
,结果是-1,为什么。本人知道计算机是用补码存储数据的,但是补码输出莫非不转换回来而是直接输出么。
然后想到了可能是溢出了,原因是int在本人计算机中是32位。除去符号位:2 147 483 648,0xffffffff出去符号位不也是31位么。
为什么?讨论了下得出的结果是存储16进制数计算机会输出的时候直接输出补码,不大相信。
mian函数以前都喜欢return 0或1,测试失败还是成功,有一次无意间返回了一次-1;
返现编译器的报告:
当时想了想,-1的补码不就是0xffffffff么,也没在意,觉得可能是直接输出的计算机存储的值。后来无聊。测试了一个结果
int nTest = 0xffffffff;
std::cout << nTest;
,结果是-1,为什么。本人知道计算机是用补码存储数据的,但是补码输出莫非不转换回来而是直接输出么。
然后想到了可能是溢出了,原因是int在本人计算机中是32位。除去符号位:2 147 483 648,0xffffffff出去符号位不也是31位么。
为什么?讨论了下得出的结果是存储16进制数计算机会输出的时候直接输出补码,不大相信。
解决方案
15
1) 关于补码
32bit 下,0xfffffff 就是 -1 。
2) 关于 C++
0xfffffff 值为 2^32-1,由于超过的 int 的表示范围,但是在 unsigned int 表示范围之内,其类型为 unsigned int, 值为 2^32-1 。
用它初始化一个 int 的是时候(int nTest = 0xffffffff;),会发生转换。
当原数据不在 int 表示范围之内的时候,转换的方式有编译器确定。
对于现在多数用补码表示整数的编译器来说,会直接将二进制表示作为补码解释,结果为 -1 。
这一转换在初始化的时候已经完成了,nTest 从始至终都是 -1 。
=============
c++ 里,数据类型决定了内存中数据将被怎么样解释。内存中的内容相同,但是类型不同,解释是不一样的。(例如,按不同数据类型解释的数值是不同的)。
在不同数据类型的数据进行赋值的时候,会发生类型的转换。这一转换并不总是将内存中的数据用目标类型重新解释一下。
32bit 下,0xfffffff 就是 -1 。
2) 关于 C++
0xfffffff 值为 2^32-1,由于超过的 int 的表示范围,但是在 unsigned int 表示范围之内,其类型为 unsigned int, 值为 2^32-1 。
用它初始化一个 int 的是时候(int nTest = 0xffffffff;),会发生转换。
当原数据不在 int 表示范围之内的时候,转换的方式有编译器确定。
对于现在多数用补码表示整数的编译器来说,会直接将二进制表示作为补码解释,结果为 -1 。
这一转换在初始化的时候已经完成了,nTest 从始至终都是 -1 。
=============
c++ 里,数据类型决定了内存中数据将被怎么样解释。内存中的内容相同,但是类型不同,解释是不一样的。(例如,按不同数据类型解释的数值是不同的)。
在不同数据类型的数据进行赋值的时候,会发生类型的转换。这一转换并不总是将内存中的数据用目标类型重新解释一下。
5
电脑内存或文件内容或传输内容只是一个一维二进制字节数组及其对应的二进制地址;
人脑才将电脑内存或文件内容或传输内容中的这个一维二进制字节数组及其对应的二进制地址的某些部分看成是整数、有符号数/无符号数、浮点数、复数、英文字母、阿拉伯数字、中文/韩文/法文……字符/字符串、汇编指令、函数、函数参数、堆、栈、数组、指针、数组指针、指针数组、数组的数组、指针的指针、二维数组、字符点阵、字符笔画的坐标、黑白二值图片、灰度图片、彩色图片、录音、视频、指纹信息、身份证信息……
人脑才将电脑内存或文件内容或传输内容中的这个一维二进制字节数组及其对应的二进制地址的某些部分看成是整数、有符号数/无符号数、浮点数、复数、英文字母、阿拉伯数字、中文/韩文/法文……字符/字符串、汇编指令、函数、函数参数、堆、栈、数组、指针、数组指针、指针数组、数组的数组、指针的指针、二维数组、字符点阵、字符笔画的坐标、黑白二值图片、灰度图片、彩色图片、录音、视频、指纹信息、身份证信息……
20
C++ 标准
https://isocpp.org/std/the-standard
http://www.open-std.org/jtc1/sc22/wg21/docs/papers/2014/n4296.pdf
不过这东西可能不太适合刚开始学者