【发布时间】:2010-11-18 22:46:23
【问题描述】:
我想在 C++ 中打印出浮点数的二进制表示。不是很实用,只是出于好奇。
以下程序无法编译。 reinterpret_cast 失败。我可以使用哪种类型的演员来完成“ &(1
#include <iostream>
using namespace std;
void toBinary(float num) {
int numi = reinterpret_cast<int>(num);
cout << num << " " << numi << endl;
for (int i = 0; i < 8 * sizeof(num); i++){
if (numi & (1<<i)) {
cout << 1;
} else {
cout << 0;
}
}
cout << endl << endl;
}
int main() {
float a;
cout << sizeof(int) << " " << sizeof(float) << endl;
a = 13.5;
toBinary(a);
toBinary(13.9);
toBinary(2 * a);
toBinary(-a);
}
【问题讨论】:
标签: c++ floating-point