原码、反码和补码详细集合

2024-06-23 13:52

本文主要是介绍原码、反码和补码详细集合,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

目录

一.什么是原码,反码,补码?

1).原码(true form):

2).反码:

3).补码:

二.为什么要有原码,反码,补码 


一.什么是原码,反码,补码?

1).原码(true form):

原码是计算机中对数字的一种二进制定点表示方法。

在原码中,取最高位用做符号位(0表示正,1表示负)其余位表示数值大小(该数真值的绝对值)。

整数:原码即其二进制。

小数:将小数部分不停乘2,每次取其整数部分,直到该数没有小数为止,每次取出的整数加起来             即使小数部分的二进制,即小数的原码。

示例:

1116个二进制位表示0000 0000 0000 1011
8个二进制位表示0000 1011
-1116个二进制位表示1000 0000 0000 1011
8个二进制位表示1000 1011
0.58个二进制位表示0000 0000. 1
-0.58个二进制位表示1000 0000. 1

由此我们可以得到:

原码的优点: 简单直观。

原码的缺点: 原码不能直接参与计算,会出错误 

2).反码:

反码是数值存储的一种,多应用于系统环境设置(如linux平台的目录和文件的默认权限的设置)。

也常用作 原码求补码 或 补码求原码 的过度码。

正数: 原码与反码相同。

负数: 原码符号位除外,其他位按位取反。

示例:

118个二进制位表示0000 1011
-118个二进制位表示1111 0100
0.58个二进制位表示0000 0000.1
-0.58个二进制位表示1111 1111.0

由此我们可以看出:

反码的有点:加减法运算规则简单,只需对应位相加并进位即可。

反码的缺单:当 0 和 -0存在不同的值。

3).补码:

补码是计算机把减法运算转化为加法运算的关键编码。

正整数: 补码和原码、反码相同。

负整数: 补码等于负整数的反码加一。

正小数:补码与原码、反码相同。

负小数:补码 . 后的值加1.

示例:

118个二进制位表示0000 1011
-118个二进制位表示1111 0101
0.258个二进制位表示0000 0000.01
-0.258个二进制位表示1111 1111.11

二.为什么要有原码,反码,补码 

由于二进制对于计算机的硬件来说,更容易实现(只有两种状态),并且有利于提高运算速度以及适应逻辑运算(真和假两种状态),所以使用二进制的形式进行存储和运算数据。

我们知道,一台计算机由运算器、控制器、存储器、输入和输出设备组成,但是其中运算器只有加法运算器,没有减法运算器。即计算机只能进行加法运算,为了实现数据的减法运算,就引入了反码的概念。但是使用反码计算时,结果的真值部分是正确的。问题其实就出现在"0"这个特殊的数值上。 虽然人们理解上+0和-0是一样的, 但是0带符号是没有任何意义的。 而且会有[0000 0000]原和[1000 0000]原两个编码表示0。于是,补码就出现了,修复了0的符号以及存在两个编码的问题, 而且还能够多表示一个最低数(从八进制整型来说,范围从(-127,127)到(-128 ,127))。

这篇关于原码、反码和补码详细集合的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/1087346

相关文章

IntelliJ IDEA 中配置 Spring MVC 环境的详细步骤及问题解决

《IntelliJIDEA中配置SpringMVC环境的详细步骤及问题解决》:本文主要介绍IntelliJIDEA中配置SpringMVC环境的详细步骤及问题解决,本文分步骤结合实例给大... 目录步骤 1:创建 Maven Web 项目步骤 2:添加 Spring MVC 依赖1、保存后执行2、将新的依赖

如何为Yarn配置国内源的详细教程

《如何为Yarn配置国内源的详细教程》在使用Yarn进行项目开发时,由于网络原因,直接使用官方源可能会导致下载速度慢或连接失败,配置国内源可以显著提高包的下载速度和稳定性,本文将详细介绍如何为Yarn... 目录一、查询当前使用的镜像源二、设置国内源1. 设置为淘宝镜像源2. 设置为其他国内源三、还原为官方

最详细安装 PostgreSQL方法及常见问题解决

《最详细安装PostgreSQL方法及常见问题解决》:本文主要介绍最详细安装PostgreSQL方法及常见问题解决,介绍了在Windows系统上安装PostgreSQL及Linux系统上安装Po... 目录一、在 Windows 系统上安装 PostgreSQL1. 下载 PostgreSQL 安装包2.

MySql match against工具详细用法

《MySqlmatchagainst工具详细用法》在MySQL中,MATCH……AGAINST是全文索引(Full-Textindex)的查询语法,它允许你对文本进行高效的全文搜素,支持自然语言搜... 目录一、全文索引的基本概念二、创建全文索引三、自然语言搜索四、布尔搜索五、相关性排序六、全文索引的限制七

python中各种常见文件的读写操作与类型转换详细指南

《python中各种常见文件的读写操作与类型转换详细指南》这篇文章主要为大家详细介绍了python中各种常见文件(txt,xls,csv,sql,二进制文件)的读写操作与类型转换,感兴趣的小伙伴可以跟... 目录1.文件txt读写标准用法1.1写入文件1.2读取文件2. 二进制文件读取3. 大文件读取3.1

Linux内核参数配置与验证详细指南

《Linux内核参数配置与验证详细指南》在Linux系统运维和性能优化中,内核参数(sysctl)的配置至关重要,本文主要来聊聊如何配置与验证这些Linux内核参数,希望对大家有一定的帮助... 目录1. 引言2. 内核参数的作用3. 如何设置内核参数3.1 临时设置(重启失效)3.2 永久设置(重启仍生效

如何在Mac上安装并配置JDK环境变量详细步骤

《如何在Mac上安装并配置JDK环境变量详细步骤》:本文主要介绍如何在Mac上安装并配置JDK环境变量详细步骤,包括下载JDK、安装JDK、配置环境变量、验证JDK配置以及可选地设置PowerSh... 目录步骤 1:下载JDK步骤 2:安装JDK步骤 3:配置环境变量1. 编辑~/.zshrc(对于zsh

使用Node.js制作图片上传服务的详细教程

《使用Node.js制作图片上传服务的详细教程》在现代Web应用开发中,图片上传是一项常见且重要的功能,借助Node.js强大的生态系统,我们可以轻松搭建高效的图片上传服务,本文将深入探讨如何使用No... 目录准备工作搭建 Express 服务器配置 multer 进行图片上传处理图片上传请求完整代码示例

C++ vector的常见用法超详细讲解

《C++vector的常见用法超详细讲解》:本文主要介绍C++vector的常见用法,包括C++中vector容器的定义、初始化方法、访问元素、常用函数及其时间复杂度,通过代码介绍的非常详细,... 目录1、vector的定义2、vector常用初始化方法1、使编程用花括号直接赋值2、使用圆括号赋值3、ve

python连接本地SQL server详细图文教程

《python连接本地SQLserver详细图文教程》在数据分析领域,经常需要从数据库中获取数据进行分析和处理,下面:本文主要介绍python连接本地SQLserver的相关资料,文中通过代码... 目录一.设置本地账号1.新建用户2.开启双重验证3,开启TCP/IP本地服务二js.python连接实例1.