-
计算机是如何区分有符号数和无符号数的
其实CPU是不需要知道数字是有符号和无符号的,他只关心外部使用的是什么指令。内部都是使用补码。 -
float/double转换为二进制
这两种类型根据IEEE规定,float使用符号位(1bit),阶码位(8bit),尾码(23bit), double使用符号位(1bit),阶码位(11bit),尾码位(52bit)。
转换:
符号位:0表示正数,1表示负数
实数.小数
实数使用除2求余的方法算出
小数使用乘2的方法算出
比如:9.25 = 0(符号位) 1001(实数) .01(小数)
–> 1001.01
–> 1.00101(向右移3位,导致阶码127+3)
–> 0(符号位) 127+3(阶码) 00101(后面补0够23位,尾码)
–> 0 10000010 0010100000000000000000
–> 01000001000101000000000000000000
–> 0x41140000
代码显示如:
float f = 9.25;
unsigned int* i = (unsigned int*)&f;
printf("%xn", *i);
3.有一个有意思的错误:
unsigned int i= 100;
do
{
–i;
printf("%xn", i);
}while(i >=0);
会死循环
欢迎分享,转载请注明来源:内存溢出
评论列表(0条)