并集浮动和整数
Union float and int
我有点困惑。在开发一个基于预定义参数的函数时,根据其类型将所需的确切参数传递给sprintf函数,我发现了非常奇怪的行为(类似于"This is%f%d example",typeFloat,typeInt)。
请查看以下剥离的工作代码:
struct Param {
enum { typeInt, typeFloat } paramType;
union {
float f;
int i;
};
};
int _tmain(int argc, _TCHAR* argv[])
{
Param p;
p.paramType = Param::typeInt;
p.i = -10;
char chOut[256];
printf( "Number is %dn", p.paramType == Param::typeInt ? p.i : p.f );
printf( "Number is %fn", p.paramType == Param::typeInt ? p.i : p.f );
return 0;
}
我的预期输出是printf( "Number is %dn", p.paramType == Param::typeInt ? p.i : p.f );
Number is -10
但它实际上打印了
Number is 0
我在初始化Param p之后放置了一个断点,尽管p.paramType
被定义为typeInt
,但if
的实际输出是-10.0000。检查p.f会得到一些未定义的值,而p.i也会显示-10。但观察窗口中的p.paramType == Param::typeInt ? p.i : p.f
评估为-10.000000。
我添加了第二个printf,将其打印为浮动,现在输出为
Number is 0
Number is -10.000000
那么为什么会发生这种情况呢?这可能是Visual Studio中的一个错误吗(我使用的是VS2012)?
更新:
std::cout<< (p.paramType == Param::typeInt ? p.i : p.f);
给出了-10的正确值。
这是因为表达式p.paramType == Param::typeInt ? p.i : p.f
的结果类型始终是float(根据paramType
的不同,只有值不同),但第一个格式字符串需要一个整数。
以下内容应该如您所期望的那样工作:
printf("Number is %dn", (int)(p.paramType == Param::typeInt ? p.i : p.f));
cout
版本为您提供了预期的输出,因为插入的表达式的类型(float
)是自动推导的,因此它将其格式化为浮点。它本质上与您的第二个printf
相同。
问题有两个方面。首先,它与printf()
有关。不要在C++代码中使用printf()
。原因与第二个问题有关。printf()
不具有类型安全性。它不知道你给它什么类型。
第二个原因是类型的工作方式。三元if语句总是返回一个float
,因为这是最合适的类型。由于int
可以隐式转换为float
,因此不会发生任何"坏"情况(除非您要打开各种"额外"警告)。所以p.i
被转换为float
,但你告诉printf()
期待int
。因此,会出现未定义的行为。您的程序不会崩溃,但它不会给您带来您所期望的结果。
- 如何反转整数参数包
- enum是C++中的宏变量还是整数变量
- 努力将整数转换为链表。不知道我在这里做错了什么
- 整数不会重复超过随机数
- 在C++中手动调整数组大小
- 检查输入是否不是整数或数字
- C++使用整数的压缩数组初始化对象
- 在C++中,将大的无符号浮点数四舍五入为整数的最佳方法是什么
- 将"打开的CV图像"中的"颜色"转换为整数格式
- 通过套接字[TCP]传输数据 如何在C / C ++中打包多个整数并使用send() recv()传输数据
- 如何只允许用户输入正整数
- 如何在c++中从文本文件中逐行读取整数
- C++:如何循环通过向量中的整数元素
- 我可以信任表示整数的浮点或双精度来保持精度吗
- 序列化,没有库的整数,得到奇怪的结果
- 在一定长度后从数组中打印时缺少整数
- std::当在256字节边界上写入整数时,流的奇怪行为
- 内联程序集printf将整数解释为地址
- 是否基于数组B整数打印数组A中的整数
- 如何在C++中将整数转换为其数字数组