同事经常面试别人的一道题:
float f = 1.0f;
int i = (int&)f;
问i=?
我也被他问过次问题,可惜没有准确地答出来。后来还抱怨,
平常工作那会用到呀。
这次还真的用到了,要求把float类型的变量按位打印出来。
第一次尝试用下面代码:
但是编译不过,因为不容许一个int类型和一个float类型做&操作。
于是就想到了那道题目。用一个int变量保存float值。
通过了,呵呵。
这个小技巧还是很有用的。
float f = 1.0f;
int i = (int&)f;
问i=?
我也被他问过次问题,可惜没有准确地答出来。后来还抱怨,
平常工作那会用到呀。
这次还真的用到了,要求把float类型的变量按位打印出来。
第一次尝试用下面代码:
#include <iostream>
using namespace std;
void main(){
float f = 1.0f;
unsigned int base = 1<<31;
for(int i=0;i<32;i++){
if((f&base)==0)
cout<<"0";
else
cout<<"1";
f = f<<1;
}
}
但是编译不过,因为不容许一个int类型和一个float类型做&操作。
于是就想到了那道题目。用一个int变量保存float值。
#include <iostream>
using namespace std;
void main(){
float f = 1.0f;
int k = (int&)f;
unsigned int base = 1<<31;
for(int i=0;i<32;i++){
if((k&base)==0)
cout<<"0";
else
cout<<"1";
k = k<<1;
}
}
通过了,呵呵。
这个小技巧还是很有用的。