作者热门文章
- android - RelativeLayout 背景可绘制重叠内容
- android - 如何链接 cpufeatures lib 以获取 native android 库?
- java - OnItemClickListener 不起作用,但 OnLongItemClickListener 在自定义 ListView 中起作用
- java - Android 文件转字符串
此程序是在 WindowsXP 机器上用 VC++6.0 编写的。
如果我尝试将 __int64 变量直接设置为 -2500000000,它会被截断为 32 位值并采用二进制补码。
__int64 testval;
testval = -2500000000;
此时 testval 等于 1794967293(110 1010 1111 1101 0000 0111 0000 0000 二进制)。
当我将变量设置为 2500000000 然后乘以负一时,它起作用了:
__int64 testval;
testval = 2500000000;
testval *= -1;
变量 testval 等于 -2500000000(二进制 1001 0101 0000 0010 1111 1001 0000 0000)。
有什么想法吗?谢谢。
最佳答案
关于c++ - 为什么我不能直接将 __int64 变量设置为 -2500000000?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/5046452/
我正在尝试在 Matlab 中使用 mex 编译一个库。我能够部分编译这个东西,但是在最后一个文件中,mex 给出了关于两行的错误: typedef __int64 LONG64; typedef _
我很惊讶地发现我的 C++ 编译器还支持 __int8、__int16、__int32 和 __int64;但我只看到它们等同于 char、short、int 和 long long。它们有什么区别?
我是一名优秀的程序员,十分优秀!