C语言之原码、反码和补码
原码、反码和补码
1).数据在内存中存储的时候都是以二进制的形式存储的.
int num = 10;
原码、反码、补码都是二进制.只不过是二进制的不同的表现形式.
数据是以补码的二进制存储的.
2). 1个int类型的变量.在内存中占据4个字节, 32位.
00000000 00000000 00000000 00000000
在不考虑正负的情况下.1个int类型的变量可以表示接近43e种数据.
为了可以表示正负性.使用最高为来表示这个数的正负性.
如果最高为是0 那么表示这个数是1个正数
如果最高为是1 那么表示这个数是1个负数.
所以,来表示数据的只有31位. 所以,1个int类型的变量.
最小值是: -2147483648 最大值是:2147483647
3). 原码
最高位表示符号位. 剩下的位数.是这个数的绝对值的二进制.
10的原码.
00000000 00000000 00000000 00001010
-8的原码.
10000000 00000000 00000000 00001000
绝对值: 正数的绝对值是自己,负数的绝对值去掉负号.
-20.
10000000 00000000 00000000 00010100
4). 反码
正数的反码就是其原码.
负数的反码就是在其原码的基础之上 符号位不变,其他位取反.
10的反码:
10的原码:00000000 00000000 00000000 00001010
10的反码:00000000 00000000 00000000 00001010
-8
-8的原码:10000000 00000000 00000000 00001000
-8的反码:11111111 11111111 11111111 11110111
5). 补码
正数的补码就是其原码.
负数的补码就是在其反码的基础之上+1
10.
10的原码:00000000 00000000 00000000 00001010
10的反码:00000000 00000000 00000000 00001010
10的补码:00000000 00000000 00000000 00001010
-8
-8的原码:10000000 00000000 00000000 00001000
-8的反码:11111111 11111111 11111111 11110111
-8的补码:11111111 11111111 11111111 11111000
6). 任何数据都是以其二进制的补码形式存储在内存中的.
int num = -8;
7). 为什么数据要以补码的形式存储呢?
计算机中只有加法没有减法.为了更加低成本的计算出结果,所以使用补码来存储数据.
3 + 2;
3 - 2; 这个减法运算对于计算机而言它的理解是 3 + (-2); 1
使用原码计算.
3的原码 00000000 00000000 00000000 00000011
-2的原码 10000000 00000000 00000000 00000010
----------------------------------------------------
10000000 00000000 00000000 00000101 结果是1个负数明显是不对的
使用反码计算.
3 的反码: 00000000 00000000 00000000 00000011
-2的反码: 11111111 11111111 11111111 11111101
--------------------------------------------------
00000000 00000000 00000000 00000000 0
使用补码计算
3 的补码: 00000000 00000000 00000000 00000011
-2的补码: 11111111 11111111 11111111 11111110
-------------------------------------------------
00000000 00000000 00000000 00000001 1
注:使用补码来做运算效率是最高的.
转载于:https://www.cnblogs.com/burningc/p/10741253.html
C语言之原码、反码和补码相关推荐
- c语言 原码反码和补码
计算机系统使用的基本上是二进制系统,数据在计算机中主要是以补码的形式存储的. 原码 一个数的原码(原始的二进制码)有如下特点: 1.最高位做为符号位,0表示正,为1表示负 2.其它数值部分就是数值本身 ...
- java用的原码还是反码_java 原码 反码 和补码
--------- 原码.补码.反码 计算机是数字电路设备,由复杂的电子元器件组合而成,一个电子元器件在工作时,可以分为两种状态--高电平和低电平,表示数据用高电平表示1,低电平表示0,而多个电子元器 ...
- 计算机原码 反码 和 补码
一.机器数和真值 1. 机器数 一个数在计算机中的二进制表示,叫做这个数的机器数.在计算机中最高位为符号位.0代表正数,1代表负数. +1 机器数(8位):0000 0001 -1 机器数(8位):1 ...
- 计算机真值范围,计算机的机器数,真值,原码, 反码和补码
机器数 一.数的符号数值化.实用的数据有正数和负数,由于计算机内部的硬件只能表示两种物理状态(用0和1表示),因此实用数据的正号"+"或负号"-",在机器里就用 ...
- 原码反码和补码,一篇就够了,全网最详细解析
其实对于计算机来说,并不存在原码和反码,计算机存储的二进制数据都是以补码的形式存放的,自然对数据的运算也是直接用补码来运算(计算机中只有加法器没有减法器) 我们都知道正整数(包括0)的补码是它本身,负 ...
- 负数的原码反码和补码
As we all know,正数的三码都一样,注意一下最高位为符号位即可: 负数的原码最高位为1,与真值之间换算方便,但对于做减法的操作却很无力,于是引进了反码和补码:负数的反码为它的正数按位取反, ...
- c语言原码 补码 反码,C语言 原码--反码--补码
//原码,反码,补码 #include #include //数值的表示方法--原码.反码和补码 //原码:最高位为符号位,其余各位为数值本身的绝对值 //反码: //正数:反码与原码相同 //负数: ...
- c语言实现单字节反码,C语言之原码、反码和补码
原码.反码和补码 1).数据在内存中存储的时候都是以二进制的形式存储的. int num = 10; 原码.反码.补码都是二进制.只不过是二进制的不同的表现形式. 数据是以补码的二进制存储的. 2). ...
- 关于计算机中 原码, 反码, 补码 详解
本篇文章讲解了计算机的原码, 反码和补码. 并且进行了深入探求了为何要使用反码和补码, 以及更进一步的论证了为何可以用反码, 补码的加法计算原码的减法. 论证部分如有不对的地方请各位牛人帮忙指正! 希 ...
- 原码, 反码, 补码, 移码 详解
本篇文章讲解了计算机的原码, 反码和补码. 并且进行了深入探求了为何要使用反码和补码, 以及更进一步的论证了为何可以用反码, 补码的加法计算原码的减法. 论证部分如有不对的地方请各位牛人帮忙指正! 希 ...
最新文章
- 很遗憾,我们正在逐渐丧失专注阅读的能力
- 基础知识《二》java的基本类型
- 构建之法 学习笔记06
- java set 包含_关于Java的Set的集合是否包括问题,如下为什么不包括?
- python规则框架_Pytest框架【2】:用例规则
- 纪事地图和Yahoo Cloud服务基准
- 程序员出差是去干什么_让我来告诉你,35岁以上的人都在干什么!
- 吴恩达深度学习 —— 2.8 计算图的导数计算
- MYSQL中的日期转换
- 项目实用-不登录就无法访问主页
- TreeList显示CheckBox
- ssm提交post_SSM中get和post乱码笔记
- 微软windows10易升_微软官网下载与安装windows10系统的操作步骤
- WebService--了解wsdl文件
- web前端之JavaScript高级程序设计六:事件
- Java十大常用框架介绍
- 2020信息系统项目管理师备战1--开篇(项目范围说明书Project Scope Statement)
- 七、项目进度管理(二)【题】
- python中test是什么意思_Python unittest 之一: 什么是单元测试
- 产权:使用权、收益权和转让权