C/C++之重读1

  1. 计算机是如何区分有符号数和无符号数的
    其实CPU是不需要知道数字是有符号和无符号的,他只关心外部使用的是什么指令。内部都是使用补码。

  2. 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("%x\n", *i);

3.有一个有意思的错误:
unsigned int i= 100;
do
{
–i;
printf("%x\n", i);
}while(i >=0);
会死循环

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值