当前位置: 首页 > article >正文

补码:计算机减法变加法的魔法(深入剖析)

1. 为什么计算机需要补码我第一次接触补码这个概念时也是一头雾水。计算机明明可以直接用二进制表示数字为什么还要搞出源码、反码、补码这么复杂的东西后来在实际项目中遇到一个简单的减法运算问题才真正理解了补码设计的精妙之处。想象一下如果计算机直接用我们熟悉的十进制方式处理减法硬件电路会变得非常复杂。每次减法运算都需要考虑借位就像小学生做减法题时要借1当10一样。这种设计不仅增加了电路复杂度还会显著降低运算速度。而补码的发明就是为了把减法运算转化为加法运算让计算机只需要一套加法器就能搞定所有事情。这里有个很形象的比喻补码就像是给数字戴上了一副魔法眼镜。当我们用补码表示负数时所有的减法运算都能神奇地变成加法运算。比如计算5-3实际上变成了5(-3的补码)结果完全正确。这种设计让计算机硬件可以保持简单高效就像只用一把螺丝刀就能完成所有组装工作。2. 源码和反码的局限性2.1 源码的致命缺陷让我们先用源码做个实验。假设我们要计算3 (-2)int a 3; // 源码00000000 00000000 00000000 00000011 int b -2; // 源码10000000 00000000 00000000 00000010 int sum a b;如果直接用源码相加结果会是10000000 00000000 00000000 00000101也就是-5。这显然不对正确答案应该是1。这就是源码的最大问题——无法正确处理负数运算。我在早期项目中就踩过这个坑。当时用源码做财务计算结果出现了莫名其妙的负数金额。调试了半天才发现是源码运算的问题最后改用补码才解决。2.2 反码的进步与不足反码改进了源码的问题它通过取反来表示负数。还是计算3 (-2)int a 3; // 反码00000000 00000000 00000000 00000011 int b -2; // 反码11111111 11111111 11111111 11111101 int sum a b;相加结果是100000000 00000000 00000000 00000000最高位溢出需要把溢出的1加回到最低位最终得到00000000 00000000 00000000 00000001也就是1。虽然结果正确了但这个过程需要额外处理溢出位效率不高。更麻烦的是反码中存在0和-0两种表示000000000 00000000 00000000 00000000-011111111 11111111 11111111 11111111这会导致比较运算时出现歧义。我在开发一个温度控制系统时就遇到过这个问题系统无法正确判断0℃是0还是-0导致控制逻辑出错。3. 补码的魔法设计3.1 补码的精妙转换补码完美解决了上述问题。它的核心思想是取反加一对负数的源码取反得到反码再加1得到补码以-2为例源码10000000 00000000 00000000 00000010 反码11111111 11111111 11111111 11111101 补码11111111 11111111 11111111 11111110 反码1现在计算3 (-2)int a 3; // 补码00000000 00000000 00000000 00000011 int b -2; // 补码11111111 11111111 11111111 11111110 int sum a b;相加结果是100000000 00000000 00000000 00000001最高位溢出的1直接丢弃剩下00000000 00000000 00000000 00000001也就是1。完全正确3.2 补码的溢出处理补码最酷的特性是高位溢出可以直接丢弃。比如计算127 18位有符号数01111111 (127) 00000001 (1) 10000000 (-128)虽然结果看起来是-128不太直观但这种设计保证了运算的一致性。我在开发音频处理程序时就利用了这个特性可以安全地忽略溢出位简化了代码逻辑。4. 补码的实际应用技巧4.1 快速计算补码在实际编程中我总结了一个快速计算补码的口诀从右往左找第一个1这个1左边的所有位取反。例如求-5的补码5的源码00000101 -5的补码11111011验证一下从右往左第一个1在最右边左边所有位取反确实得到11111011。4.2 补码的范围特性n位补码能表示的范围是[-2^(n-1), 2^(n-1)-1]。比如8位补码最小值10000000 (-128)最大值01111111 (127)这个特性在内存优化时特别有用。我在嵌入式开发中经常根据数据范围选择合适的数据类型比如知道数值不会超过100时就用int8_t可以节省内存。4.3 补码的硬件优势现代CPU的ALU算术逻辑单元都是基于补码设计的。我曾经用Verilog实现过一个简单的8位CPU补码设计让加法器电路减少了约30%的逻辑门。这解释了为什么所有现代计算机都采用补码——它确实是最优解。在实际项目中理解补码还能帮助调试一些奇怪的数值问题。比如当看到0xFFFFFFFF时知道它可能是-1的补码表示而不是4294967295在32位有符号整数情况下。这种洞察力往往能快速定位一些隐蔽的bug。

相关文章:

补码:计算机减法变加法的魔法(深入剖析)

1. 为什么计算机需要补码? 我第一次接触补码这个概念时,也是一头雾水。计算机明明可以直接用二进制表示数字,为什么还要搞出源码、反码、补码这么复杂的东西?后来在实际项目中遇到一个简单的减法运算问题,才真正理解了…...

OpenCV中solvePnP的EPnP选项到底是怎么工作的?一个代码与公式的对照解析

OpenCV中solvePnP的EPnP选项到底是怎么工作的?一个代码与公式的对照解析 当你在计算机视觉项目中调用cv::solvePnP函数并选择SOLVEPNP_EPNP标志时,是否曾好奇这个黑箱内部究竟发生了什么?本文将以代码实现与数学公式双重视角,为你…...

技术人如何从肯尼迪就职演说中学习高效沟通与演讲技巧(附英文原文精读)

技术人如何从肯尼迪就职演说中学习高效沟通与演讲技巧 当技术人站在会议室白板前讲解架构设计,或在行业峰会聚光灯下演示创新成果时,有多少人思考过:为什么有些技术分享令人昏昏欲睡,而有些却能引发全场共鸣?肯尼迪196…...

如何查询SQL数据库的连接数状态_查询全局运行参数

查MySQL连接数应根据需求选择:SHOW STATUS LIKE Threads_connected获当前打开连接数(含空闲),轻量适合监控;SHOW PROCESSLIST列线程详情(含SQL、用户、状态),但权限受限且默认仅前10…...

python kics

## 关于 Python KICS,一次不那么官方的漫谈 最近在几个基础架构和安全相关的项目里,又遇到了那个老生常谈的问题:如何在代码部署前,就发现那些隐藏在基础设施即代码(IaC)配置里的安全隐患?像 Te…...

python tfsec

## 关于 Python 中的 tfsec:一个安全工程师的视角 如果你在 Python 项目中处理过 Terraform 代码,或者你的团队同时维护着基础设施即代码和应用程序代码,那么你很可能遇到过这样一个问题:如何确保那些定义云资源的 .tf 文件是安全…...

python terrascan

# 聊聊Python Terrascan:当IaC安全遇上Python的灵活 最近在基础设施即代码(IaC)安全扫描这个领域,有个工具逐渐引起了注意——Python Terrascan。它不是那种一夜爆红的技术,而是随着云原生和DevSecOps的普及&#xff0…...

为什么大家都说嘎嘎降AI好用?深度解读降AI率工具好坏的本质

为什么大家都说嘎嘎降AI好用?深度解读降AI率工具好坏的本质 一、一个口碑现象:嘎嘎降AI是怎么火起来的? 2026年毕业季,有个明显的趋势:在知乎、小红书、B站等平台上,嘎嘎降AI被提到的频率越来越高。不是自吹自擂的广告帖,而是真实用户在分享"终于过了"…...

SSL/TLS 的演进

在学习SSL和TLS握手过程中,书上(计算机网络:自顶向下的方法)和博客文章,总会有一些出入和矛盾点,让我摸不着头脑,所以我通过 AI 对 SSL 和 TLS 各个版本握手模式进行了总结,希望帮到…...

降AI率工具哪个好?背后的判断逻辑你可能没想过

降AI率工具哪个好?背后的判断逻辑你可能没想过 一、一个被问烂了的问题,却很少有人答对 “降AI率工具哪个好?”——这是2026年毕业季被问得最多的问题之一。打开知乎、小红书、百度贴吧,铺天盖地的测评、排行榜、推荐帖,但真正能帮你做决策的内容寥寥无几。 为什…...

typedef ap_axiu<24, 1, 0, 0> axis_pkt_t综合工具报错原因

// 文件名: axi_to_video.h #ifndef FRAME_TOP_H_ #define FRAME_TOP_H_//#include "ap_int.h" #include "hls_stream.h"#include "ap_axi_sdata.h"// 定义带边带信号的 AXI4-Stream 数据类型 // 数据宽度 24 位(RGB888)&…...

降AI率工具哪个好?教你用免费额度筛选出最适合的

降AI率工具哪个好?教你用免费额度筛选出最适合的 买东西之前先试用,这个常识在选降AI率工具时同样适用。现在主流工具基本都提供免费额度,白嫖的机会不用白不用。今天教你一套"用免费额度筛选最适合工具"的完整方法,跟…...

用信捷PLC定时器和计数器做一个200秒延时:从梯形图到仿真监控的全过程

用信捷PLC实现200秒延时的可视化调试全攻略 在工业自动化控制领域,PLC编程的逻辑抽象性常常让初学者感到困惑。特别是当涉及到定时器和计数器的组合应用时,仅靠静态的梯形图很难真正理解程序运行的动态过程。本文将带您深入探索如何利用信捷PLC编程软件的…...

2026年,杭州靠谱GEO服务商大揭秘,带你开启精准营销新体验!

在数字化营销的浪潮中,GEO(地理定位)营销凭借其精准触达目标客户的优势,成为众多实体商家提升业绩的关键手段。在杭州,有不少GEO服务商,其中成都煜见科技有限公司脱颖而出。接下来,我们就一起深…...

FanControl:如何让Windows电脑风扇既安静又高效?一个开源解决方案的深度指南

FanControl:如何让Windows电脑风扇既安静又高效?一个开源解决方案的深度指南 【免费下载链接】FanControl.Releases This is the release repository for Fan Control, a highly customizable fan controlling software for Windows. 项目地址: https:…...

Linux输入子系统实战:从struct input_event到鼠标、键盘、触屏事件解析与编程

1. Linux输入子系统入门:从设备文件到事件流 刚接触Linux输入子系统时,我花了整整三天才搞明白/dev/input/eventX这些神秘文件背后的门道。简单来说,Linux把所有的输入设备——键盘、鼠标、触摸屏、游戏手柄——都抽象成了文件。当你按下键盘…...

别再对着英文手册发愁了!手把手教你用STM32CubeMX配置AD7705(附完整代码)

STM32CubeMX实战:AD7705高精度ADC配置全解析 在嵌入式系统开发中,模拟信号采集是常见需求。AD7705作为一款16位Σ-Δ型ADC芯片,以其高精度和低功耗特性广泛应用于工业测量领域。本文将详细介绍如何利用STM32CubeMX图形化工具快速配置AD7705&a…...

多客圈子论坛代码审计(PHP代码审计)

前言:前几天看到同学发来了一个漏洞分析的报告,想着来分析分析源代码,就有了这篇文章,第一次写代码审计的文章,可能会有很多不足点,欢迎大家批评指正,谢谢! 项目源代码:https://pan…...

从专项到性能:APP质量保障实战指南与SoloPi工具深度解析

1. APP质量保障的核心逻辑 刚入行做移动测试那会儿,我总以为功能测试就是点点按钮。直到有次上线后用户集体投诉APP卡死,才明白质量保障远不止表面功能验证。真正专业的测试工程师,需要建立从专项到性能的完整质量评估体系。 APP质量保障本质…...

STM32F103驱动AD9959 DDS信号发生器:从CubeMX引脚配置到四通道频率调节实战

STM32F103驱动AD9959 DDS信号发生器实战指南 在电子设计竞赛和嵌入式系统开发中,DDS(直接数字频率合成)技术因其高精度、快速频率切换和相位可编程等优势,成为信号发生器设计的首选方案。AD9959作为一款四通道DDS芯片,…...

Mac新手必看:保姆级Git+SourceTree配置指南,从安装到拉取代码一气呵成

Mac新手必看:保姆级GitSourceTree配置指南,从安装到拉取代码一气呵成 刚接触开发的Mac用户,面对Git命令行操作往往一头雾水。SourceTree作为图形化工具能大幅降低学习门槛,但初始配置过程仍可能让新手手足无措。本文将用最直观的方…...

手把手教你用FS8A15S8设计小风扇:从电路图到实现多档升压(5.5V/6.8V/8V)

基于FS8A15S8的智能小风扇开发实战:多档升压与安全保护全解析 在创客社区和嵌入式开发领域,小型便携设备的电源管理一直是热门话题。最近一年,支持多档位电压输出的手持小风扇方案在DIY爱好者中特别流行——不仅因为其实用性,更因…...

MongoPlus 教程

一、MongoPlus 简介MongoPlus 是一个基于 MyBatis-Plus 思想设计的 MongoDB ORM 框架,提供了类似 MyBatis-Plus 的便捷操作体验。⚠️ 注意:MyBatis-Plus 本身是针对关系型数据库(MySQL、PostgreSQL等)的增强工具,并不…...

Substance 3D Painter Pt 2025 v11.0.1详细图文安装教程

软件简介:Substance 3D Painter(简称 Pt/SP)是 Adobe 推出的专业 3D 材质与纹理绘制软件,主要面向游戏、影视动画、产品渲染等行业,负责给 3D 模型制作真实感表面效果,比如金属、布料、划痕、锈迹、磨损等质…...

别再只会用‘w‘和‘r‘了!Matlab fopen函数权限参数全解析(含编码与字节序)

别再只会用w和r了!Matlab fopen函数权限参数全解析(含编码与字节序) 在Matlab文件操作中,fopen函数就像一把瑞士军刀——大多数人只使用最基本的"开瓶器"功能(r和w模式),却忽略了它真…...

还在用简单 AI 对话?Spring AI 自定义工具 + MCP 协议直接打通外部服务!

前言 本文的示例基于上一篇博客Spring AI 对话记忆不丢失!MySQL 主存 Redis 缓存实战(免费模型调用附源码)-CSDN博客的 已有项目继续开发 。如果你对项目结构、基础配置(ChatClient、ChatMemory、双写策略等)不清晰&…...

从零训练一个小模型-nanoGPT 模型训练 (一)数据预处理

最近在学习模型训练,实际上在大模型训练上,我并没有深厚的背景,通过视频课程和b站上的一些分享,开始入门。 由于我非神经网络这些相关的专业,所以想把自己学习的过程和经验总结记录下来,一方面自己可以巩固…...

C++数据结构--回溯算法

一.什么是回溯算法算法思想:在包含问题的所有解的解空间树中,按照深度优先搜索的策略,从根节点出发深度搜索解空间树。当搜索到某一节点时,要先判断该节点是否包含问题的解;如果包含就从该节点出发继续深度搜索下去,否则逐层向上回溯。一般在搜索的过程中都会添加相应的剪枝函数…...

【流量分析】Wireshark v4.6.4

简介 Wireshark 是一款非常棒的Unix和Windows上的开源网络协议分析器。它可以实时检测网络通讯数据,也可以检测其抓取的网络通讯数据快照文件。可以通过图形界面浏览这些数据,可以查看网络通讯数据包中每一层的详细内容。Wireshark拥有许多强大的特性&a…...

AI专题学习笔记

token 提示词:零样本、少样本、链式思考、自动思维链、自我一致性、思维树(走迷宫)、 RAG(肯德基最新汉堡的口味)、Fine-tuning(7年时间学医):用于提高语音模型在特定任务上的性能 向量:embedding 向量相似度计算:欧式距离、余弦相…...