Java日常

原码,反码,补码

原码, 反码, 补码是机器存储一个具体数字的编码方式

8位二进制位中 第一位表示符号位,其余位是编码位

⑴ 原码:数据的二进制表达形式。

⑵ 反码:正数的反码不变,负数的反码在原码的基础上除了符号位,其他都取反。

⑶ 补码:正数的补码不变,负数的补码在原码的基础上除了符号位取反,并且在最后位上加一。

在计算机中运行减法运算时,可以将减去一个数转换成加上这个数的负数。因为在数据的二进制表达中,数据的正负是通过最高位的数字来表示的(0表示正数,1表示负数),如果计算机进行运算时对符号位进行辨认后再操作,那么程序就太过复杂了。为了在计算过程中将符号位也带入运算,简化运算步骤,将计算机中的减数都转换成加上这个数的负数。

计算机中进行数字操作运算是使用补码进行的,补码的补码等于原码,数据在内存中以二进制补码的形式存储。

 

大小端

—————— ————————

低地址 高地址

ox1234abcd的大小端存储

大端存储:12 34 ab cd

小端存储:cd ad 34 12

小端存储

低位放低地址,高位放高地址

 

大端存储

高位放低地址,低位放高地址

 

32位机器是小端存储

 

#include <iostream.h>

#include <iomanip.h>

union Num

{ char a[4];  

int b;  

};

void main()  

{ Num x;

  x.a[0]=‘A’;  

x.a[1]=‘B’;

  x.a[2]=‘C’;

x.a[3]=‘D’;

cout<<x.a<<endl;

  cout<<x.b<<endl;

cout<<hex<<x.b<<endl;  

}  

————————————————

版权声明:本文为CSDN博主「小小小小滴」的原创文章,遵循CC 4.0 BY-SA版权协议,转载请附上原文出处链接及本声明。

原文链接:https://blog.csdn.net/ip66666/article/details/109313526

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值