C++铸造 int 到双倍
C++ casting int to double
我不是一个C++开发人员,但今天我找到了C++代码并尝试理解它。所以我堆叠了这段代码:
int m = 2, n = 3, i = 1;
double mid = (double)m / n * i;
int d = (int)mid + 1;
printf("%d %dn", mid, d);
将要打印到控制台的结果是:1431655765 1071994197。这似乎与变量 m 转换为双倍有关,但我不知道它是怎么发生的。我需要有人帮助我理解它。提前感谢!
您应该在 printf
中打印带有 %lf
格式说明符的双精度( mid
)。
将 printf 更改为
printf("%f %in", mid, d);
将实际打印您所期望的内容,即 0.666667 1
一个更简单的解决方法是
double m_Doubled;
m_Doubled = static_cast(m);
相关文章:
- 为什么在全局范围内使用"extern int a"似乎不行?
- int(c) 和 c-'0' 之间的区别。C++
- C++中的动态铸造故障
- 从"int*"强制转换为"unsigned int"会丢失精度错误
- 为什么野牛仍在使用"int yylex(void)",却找不到"int yylex(YYS
- 有符号的int和int-有没有一种方法可以在C++中区分它们
- 请解释这句话(cout<<1+int((a<b)^((b-a)&1) )<<endl
- 是否可以从int转换为enum类类型
- 不能在初始值设定项列表中将非常量表达式从类型 'int' 缩小到'unsigned long long'
- 向量 <int> a {N, 0} 和 int arr a[N] = {0} 的时间复杂度有什么区别
- 'short int'持有的值溢出,但"自动"不会溢出?
- 如何在C++中将一个无符号的 int 转换为两个无符号的短裤?
- 调用'begin(int [n])'没有匹配函数
- G锁定铸造到基础上会释放模拟行为
- 没有显式声明的int[]中的foreach
- 在c++中访问int到类对象的映射时出错
- 如何在C++中静态铸造 2D 矢量大小()(size_t 到 int)
- C++铸造 int 到双倍
- C++ 弹性<<字符(int)铸造的EOF
- 有可能的方法可以将两个从无符号 int 铸造的浮点数除以产生负浮点数结果