一、一个输出float类型的数对应的二进制形式的C++程序
最近在学汇编,有其中一个程序是,让你输出float类型的数的对应二进制形式,具体程序如下:
#include <iostream>
using namespace std;
int main(){
//float类型占四个字节,长32位
float f;
int j;
cout<<"please input a float:";
cin>>f;
cout<<"the binary form of the float is :"<<endl;
//char类型只占一个字节,长8位
char *p;
p=(char*)&f;
//从float这四个字节的最后一个字节开始输出,因为IntelCPU的数据存储格式是小尾原则(即高地址存放高位字节,低地址存放低位字节)
for(j=3;j>=0;j--){
//取出float中的第j个字节
int m=*(p+j);
//k为掩膜,以从高到低地取出对应的位值
for(int k=128;k>=1;k=k/2){
if(m&k)
cout<<'1';
else
cout<<'0';
}
cout<<" ";
}
cout<<endl;
return 0;
}
二、分析程序
这个程序很简单。但是发现其中的两句有点奇怪:
int m=*(p+j);
for(int k=128;k>=1;k=k/2){
我想,c++中的char类型是只占一个字节,要取出float中四个字节中的某个字节,何不直接用char类来取呢? 而是用
int m=*(p+j);
一个int 类型这个占四个字节的类型来取一个字节呢?
同样道理,掩膜k也应该是用char类型更合适,节省空间啊。
于是,我把m和k的类型都改成了char类型,在vim g++重新运行后,发现:竟然完全没有输出!然后,重新测试了int m;char k、char m;int k这两个组合,发现char m;int k这个组合可以运行成功。因此,出错的地方肯定在于char k=128这里。
三、分析解决问题
到这里,我百思不得其解,上网百度了一下char类型,上面说,在C++里,char类型是比较特殊的一个,因为像int,float等类型,不说明是否有符号的话,就是默认为有符号。而char不同,它在没有说明的情况下,就是默认为无符号的。
照这样说,char类型在默认情况下为无符号,而且占一个字节,那么它的范围应该为0-255才对。这样的话,char k=128不应该出错才对。
后来,查到一篇CSDN的贴吧,有人说char有三种类型:
类型 数值范围
char 0-127
unsigned char 0-255
signed char -128-127
因此 我尝试着把char k=128改成char k=127后,居然成功了。因此,只要把char k改成(unsigned char)k就好了。改后程序如下:
<img src="https://img-blog.csdn.net/20140819194644406" alt="" />
#include <iostream>
using namespace std;
int main(){
float f;
int j;
cout<<"please input a float:";
cin>>f;
cout<<"the binary form of the float is :"<<endl;
char *p;
p=(char*)&f;
for(j=3;j>=0;j--){
char m=*(p+j);
unsigned char k;
for(k=128;k>=1;k=k/2){
if(m&k)
cout<<'1';
else
cout<<'0';
}
cout<<" ";
}
cout<<endl;
return 0;
}
四、总结
至于char类型为什么和unsigned char类型的数值范围不一致,我就不得而知了。求大牛路过知晓,能告之鄙人,鄙人将不胜感激!