二进制与二进制运算


1. 二进制与十进制

1. 1-原码

原码(true form)是一种计算机中对数字的二进制定点表示方法。原码表示法在数值前面增加了一位符号位(即最高位为符号位):正数该位为0,负数该位为1(0有两种表示:+0和-0),其余位表示数值的大小。(-百度百科)
缺点:不能直接参与运算,对于值相等的正负数字相加,往往得不到结果‘0’。如0000_1110(14)+1000_1110(-14)=1001_1100。

1. 2-反码

反码通常是用来由原码求补码或者由补码求原码的过渡码。反码跟原码是正数时,一样;负数时,反码就是原码符号位除外,其他位按位取反。(-百度百科)

1. 3-补码(原码反码没啥好说的,重点是这里)

1. 3.1-为嘛要选择这么麻烦的记录方式

要说这个问题,就要回到原码中,因为原码不能直接参与运算,例如在日常中-4+4的结果是0,但是换成原码相加,则结果肯定不是0,不管你是否忽略掉符合位。

那么,如何记录数字?(-百度百科

先说一个问题,如何让指针指向0点(以时钟为例,时钟是12进制,也更好理解,下图我自己将12该成0,这样更符合计算机中的数字)

答案是两种:
顺时针拨动4个小时和逆时针波动8个小时。分别代表了两种运算{8点钟加4小时}与{8点中减8小时},即8+4=8-8。然后就可以知道,4等价于-8
顺便多一句,你可能对于顺时针的拨动的“4”,是不加思考,由生活经验直接口算出来的,这个“4”其实就是钟表上的数字个数(12,0-11是12个数字)减去当前值(8)得出的 8+(12-8)。
进一步推到,上面的4等价于-8得到12-8=-8


ok,有了这些信息,下一步就用到计算机存储中。 以byte为例,规定一下符号位在最高为,0正1负,那我们还剩下7个位可以存储。 假如要存储-6,根据上面例子推出的,其实也可以存储 **byte的能表示的数字个数(111_1111+1)-6**,用原码运算一下,就是下图

 

切记切记 到这里还没有完,别忘了,上图中的被减数是byte的最大值,但是理应是byte的能表示的数字个数,所以我们要在结果上在加1。

最终,再加上符号位1,最终结果,就是1111_1010


比较一下+6的二进制与-6的二进制

得出结论:-6的表示方法为+6的反码+1,符号为1(正数的补码就是原码,负数的补码就是符号位不动,其正数的反码+1)


关于+6与-6的补码相加运算就不展开验证了,就当个作业吧,看到的在评论区自觉完成~。

附记:关于这些也是自己刚看的,一直好奇补码的这种存储方式,百度百科是以钟表为例,其实本质都是一样,当前任意值一直加加加,就会陷入循环往复之中,早晚会与起始值相同。(byte最大值+1是0,因为溢出了~)。
此篇结束也留下个疑问,为什么负数的补码会与正数的反码+1恰好相等,还是说我这种推导是错误的。
最后,如有纰漏,不吝赐教。

CSCODE.NET开发框架文库 - C/S架构winform开发框架

CSCODE.NET开发框架文库 - C/S架构Winform开发框架

版权声明:本文为开发框架文库发布内容,转载请附上原文出处连接
C/S框架网
上一篇:C# Byte数组操作
下一篇:在ASP.NET Core web API中使用Swagger/OpenAPI(Swashbuckle)
评论列表

发表评论

评论内容
昵称:
关联文章

二进制二进制运算
C# LINQ MRP物料需求运算模板代码
将截断字符串或二进制数据。语句已终止
多语言切换到英文版登陆报错:截断字符串或二进制数据
C#EF保存数据DbUpdateException异常:将截断字符串或二进制数据
开发框架使用.NET Reactor(加壳+代码混淆)加密狗加密有什么区别
软件开发设计 - ERP-企业资源计划管理系统(润祥文化ERP数据库设计)
Winform快速开发框架之权限系统设计(1) - 基本概述
软件开发设计 - GIS-地理信息系统(泰州市大比例尺基础地形图数据库设计)
软件开发设计 - GIS-地理信息系统-配电地理信息系统
软件开发设计 - OA-办公自动化-activiti5.13框架数据库表
TypeConverterExpandableObjectConverter
【原创】WebApi开发框架:Token生成、Token缓存原理、Token验证、令牌机制原理
数据字典业务表的数据关系查询
Winform C/S结构Web B/S结构开发MES/ERP系统优缺点及区别
WCFWeb Service的区别关系
WinFramework项目初始化配置运行程序
StringStringBuilder的区别
平台支持数据导入导出吗?
如何付款交付源码?

热门标签
.NET5 .NET6 .NET7 APP Auth-软件授权注册系统 Axios B/S B/S开发框架 Bug Bug记录 C#加密解密 C#源码 C/S CHATGPT CMS系统 CodeGenerator CSFramework.DB CSFramework.EF CSFrameworkV1学习版 CSFrameworkV2标准版 CSFrameworkV3高级版 CSFrameworkV4企业版 CSFrameworkV5旗舰版 CSFrameworkV6.0 DAL数据访问层 Database datalock DbFramework Demo教学 Demo下载 DevExpress教程 DOM EF框架 Element-UI EntityFramework ERP ES6 Excel FastReport GIT HR IDatabase IIS JavaScript LINQ MES MiniFramework MIS NavBarControl Node.JS NPM OMS ORM PaaS POS Promise API Redis SAP SEO SQL SQLConnector TMS系统 Token令牌 VS2022 VSCode VUE WCF WebApi WebApi NETCore WebApi框架 WEB开发框架 Windows服务 Winform 开发框架 Winform 开发平台 WinFramework Workflow工作流 Workflow流程引擎 版本区别 报表 踩坑日记 操作手册 代码生成器 迭代开发记录 基础资料窗体 架构设计 角色权限 开发sce 开发技巧 开发教程 开发框架 开发平台 开发指南 客户案例 快速搭站系统 快速开发平台 秘钥 密钥 权限设计 软件报价 软件测试报告 软件简介 软件开发框架 软件开发平台 软件开发文档 软件体系架构 软件下载 软著证书 三层架构 设计模式 生成代码 实用小技巧 收钱音箱 数据锁 数据同步 微信小程序 未解决问题 文档下载 喜鹊ERP 喜鹊软件 系统对接 详细设计说明书 行政区域数据库 需求分析 疑难杂症 蝇量级框架 蝇量框架 用户管理 用户开发手册 用户控件 在线支付 纸箱ERP 智能语音收款机 自定义窗体 自定义组件 自动升级程序