数据的存储

原反补

此时符号位也参与了运算 

这个列子反应了 数据存储用补码的原因

使用补码,可以将符号位和数值域统一处理;上述例子正数1负数-1符号位为0和1

同时,加法和减法也可以统一处理(CPU只有加法器);上述例子使用补码相加得到正确结果,如果使用原码计算错误

补码与原码相互转换,其运算过程 是相同的,不需要额外的硬件电路。
:原码到补码 ---取反,+1
     补码到原码  ----取反,+1  or    -1再取反

例题

对于char来说 在整型提升时候认定高位为符号位,所以提升时,提升的是char变量如10000000就提升的是1,如果是0就补充0
对于unsigned  整形提升时,不认定高位为符号位,提升补充0
例如char  a = -128截断后10000000  的高位为1
        char  a = 128截断后10000000  的高位也为1
        所以提升都 提升1

大小端

为什么有大小端呢?

如果数据超过了1个字节,那么存储时就有一个顺序问题,最后保留了大端和小段这种方式

在Debug里面看到的是十六进制

1个十六进制用4个二进制位(也就是bit位)来存储(因为16进制范围0~15,二进制1 1 1 1,8421=15)

2个16进制-----8bit ------1字节

所以上述int为4字节

浮点数在内存中存储

浮点型为float 和 double 一个4字节一个8字节超过了1字节所在在内存中也需要小端存储

3.1415

1E10:表示为:1.0 * 10^10

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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值