关于标志信息ZF、OF、SF、CF的理解

article/2025/8/30 1:39:56

带标志加法器结构

零标志ZF

零标志是根据每一位加法器的计算结果 F i F_i Fi相或得到的,所以只有在结果的每一位都为0的时候所有位相或才能得到0的输出,但是或门上有取反符号,所以在ZF标志的输出为1时代表结果全零,反之不全为0.

溢出标志OF

注意OF是判断带符号数是否溢出的,对于无符号数OF不能用作溢出的判断,因为如果两个高位为0的数相加,得到的结果高位为1,明显对于无符号数这种情况是可以成立的,但是对于带符号数,证明其得到的结果是负数,由两个正数做和还得到了一个负数结果明显是溢出。所以在OF为溢出的情况下,对于无符号数是不能由此就判断无符号数的结果是否溢出的。

由上面的加法器结构可以看到,判断溢出没有可以通过最高位的 C o u t ( C n ) C_{out}(C_n) Cout(Cn) C n − 1 C_{n-1} Cn1求异或得到。下面是所有的输入输出情况可见,最高位的 C o u t ( C n ) C_{out}(C_n) Cout(Cn) C n − 1 C_{n-1} Cn1OF之间是满足异或关系的。

符号标志SF

表示带符号整数加减运算结果的符号位,因此直接取结果的最高位作为SF

进/借位标志CF

之前说的判断带符号数的溢出标志是OF,那么现在判断无符号数的溢出标志就是CF,同样CF只能判断无符号数是否溢出(溢出为1,反之为0),而不能判断带符号数的溢出情况。

其实这四个标志里CF是最令我费解的。由结构图可知 C F = C o u t ( C n ) ⊕ C i n CF=C_{out}(C_n)\ \oplus\ C_{in} CF=Cout(Cn)  Cin求得。进位是很好理解的,进位一般是对于加法而言,而 C i n C_{in} Cin是输入加减符号的对应,所以这时候 C i n = 0 C_{in} = 0 Cin=0,那么当 C o u t ( C n ) = 1 C_{out}(C_n) = 1 Cout(Cn)=1 C F = 1 CF=1 CF=1表示有溢出。因为最高位处都还要向前面进位,而得到的结果会舍去最高位前面的所有值,所以自然发生了溢出。但是对于借位,我觉得真的很难理解,借位是对于减法而言的,如果在减法里还想要结果不溢出那么最高位必须让 C o u t = 1 C_{out}=1 Cout=1才可以。对于这一点想了很久终于明白了:

我们首先以四位的数为例子,有真值为 a , b a, b a,b的两个四位无符号数。他们的机器数,也就是补码表示为 A , B A,B A,B,对于 a − b a-b ab的计算可以写成 a − b = a + [ − b ] 补 = A + [ − b ] 补 a-b=a+[-b]_{补}=A+[-b]_{补} ab=a+[b]=A+[b]而对于这个 [ − b ] 补 [-b]_补 [b],可以通过对 b b b的补码各位取反,末位加一得到这个过程写出来是这样的:
1111 − B + 1 = 10000 − B 1111-B+1=10000-B 1111B+1=10000B
那么对于 a − b a-b ab可以表示成:
A − B + 10000 A-B+10000 AB+10000
那么对于无符号数而言做减时得到为正数的结果自然是没有发生溢出的,但是如果得到的结果为负数,那么必然发生溢出,而上面的式子很容易看到,经过这样的求值过程如果说A-B是正数,那么必然会因为 + 10000 +10000 +10000而发生进位,如果A-B的值不够为正数,那么A必然会向 + 10000 +10000 +10000借位,那么就必然不会产生进位。

综上, C F CF CF的由来就是如此。


http://chatgpt.dhexx.cn/article/MYNonokM.shtml

相关文章

CF、SF、OF、ZF标志位

没学汇编,这种题我真是做一道错一道:-( OF(overflow flag) 溢出标志位 溢出标志位 OF 1 表示带符号整数运算时结果发生溢出。对于无符号整数运算,OF没有意义。 对于有符号数的溢出判断方式有: 1)采用一位符号位:思想…

cgo如何调用c++库

将c代码打包成静态库,再通过cgo调用,一直链接不上。起初以为是cgo只能用gcc,而我的静态库是是用g编译的,其实不然。 cgo调用c库,只需要在cpp源代码 include 头文件的时候,加上 extern "C" 就行了…

golang cgo 使用总结

文章目录 参数传递 基本数值类型切片字符串其他类型总结参考资料 CGO 提供了 golang 和 C 语言相互调用的机制。某些第三方库可能只有 C/C 的实现,完全用纯 golang 的实现可能工程浩大,这时候 CGO 就派上用场了。可以通 CGO 在 golang 在调用 C 的接口…

CGO总结

概述 cgo作为一个强大的工具,可以让go轻松实现调用c语言的巨额遗产。。。 问题 实际开发中,发现使用go语言调用c的动态库时,经常出现传入c的字符串发生变化的现象,如下: 情况1 由a.txt变为a.txt$\n 情况2 由plai…

cgo 机制 - 从 c 调用 go

文|朱德江(GitHub ID:doujiang24) MOSN 项目核心开发者 蚂蚁集团技术专家 专注于云原生网关研发的相关工作 本文 4656 字 阅读 12 分钟 一、前言 去年刚学 go 语言的时候,写了这篇 cgo 实现机制[1] ,介绍了 cgo 的基本…

深入学习CGO

深入学习CGO 快速入门基础知识import "C" 语句#cgo语句 GO与C的类型转换CGO函数调用CGO内部机制CGO内存模型C类封装成C APICGO调用在go runtime 层面的处理CGO的静态/动态库封装以及编译链接参数CGO定位内存泄露CGO性能CGO最佳使用场景总结参考文献: 很多…

快速上手 CGO,掌握在 Go 里写 C!

大家好,最近因为各种奇怪的原因,接触到了 Go 特色之一 CGO。这方面的相关内容也相对少一些,给大家抛砖引玉,有经验的大佬欢迎补充。 图片来源于 marlin 毕竟很多跨语言调用,还是会依赖 CGO 这个特性。希望大家在真正要…

DevOps学习心得总结

流程步骤: 1、PLAN 制定计划 (牢记交付给用户的目标) 2、CODE 开始编码 (使用相同的代码,不同版本的代码存储到仓库中,借助Git等工具在需要时合并【版本控制】) 3、BUILD 构建阶段…

DevOps工具链

DevOps是敏捷研发中持续构建(Continuous Build,CB)、持续集成(Continuous Integration,CI)、持续交付(Continuous Delivery,CD)的自然延伸,从研发周期向右扩展…

DevOps及DevOps常用的工具介绍

目录 1. 什么是 DevOps2. DevOps 概念的起源2.1. 单体架构 瀑布模式2.2. 分布式架构 敏捷开发模式2.2.1. 多人协同开发问题2.2.2. 多机器问题2.2.3. 开发和运维角色的天生对立问题 2.3. 微服务架构 DevOps 3. DevOps 到底是什么4. DevOps 常用的工具4.1. Jenkins4.2. Kubern…

DevOps 简史

【注】本文节译自:https://www.bmc.com/blogs/devops-history/   IT 行业的当前状态受技术进步在整个历史中所产生的连锁效应所影响。不时出现的新技术极大地改变了世界运转的方式。最近,技术进步似乎开始以惊人的速度出现。自从互联网出现以来&#…

DevOps 学习

目录 一、概述 1、CI/CD简介 二、Git简介 三、Jenkins简介 一、概述 DevOps是Development和Operations的组合,也就是开发和运维的简写。 DevOps集文化理念、实践与工具于一身,可以提高组织高速交付应用程序和服务的能力,与使用传统软件…

DevOps实践

数字化时代,技术的交付速度和质量,直接关系业务的发展和创新。IT 技术交付和运行的效率,成为决定数字化转型成败的关键,而 DevOps 要解决的问题正在于此,DevOps 成为数字化转型的重要一环。 能力构建 随着云原生技术的…

DevOps的前世今生

导语 DevOps诞生已经13年了,你理解他吗? 为什么相伴了13年,你仍然对他不甚了了呢? 你真的以为DevOps是一个筐,什么东西都可以往里装吗? 你以为DevOps落地就是找一个JIRA(敏捷管理工具&#…

Learning DevOps

什么是 DevOps DevOps(Development & Operations)/de’vps/ 是一组过程、方法与系统的统称,用于促进开发 (Dev)、技术运营 (Ops)和质量保障(QA)部门之间的沟通、协作与整合。 DevOps 的开发流程 软件从零开始到…

DevOps思想

什么是DevOps? DevOps是一种思想或方法论,它涵盖了开发、测试、运维的整个过程!DevOps强调开发、测试、运维、质检(QA)部门之间的有效沟通与协作。强调通过自动化的方法管理软件变更、软件集成。使软件从构建到测试、发布更加快捷、可靠&…

DevOps的发展史

公众号关注 「奇妙的 Linux 世界」 设为「星标」,每天带你玩转 Linux ! — 1 — 可操作的概述 多亏了云计算和开源,软件开发的速度从几年缩短到几个月。每家公司都在向一个软件公司转变。DevOps 已迅速成为公司大规模开发和部署软件的最有效方…

DevOps——简析

节选自百度等资料 知乎解析连接 一、DevOps的目的 只有一个:提高开发到运维发布版本的效率。 1.初级应用:开发运维一体化 2.最高阶的应用:端到端的概念。 DevOps 的三大支柱之中,即人(People)、流程&…

DevOps推广实践总结

中大型团队在敏捷DevOps转型过程中常见的实践总结 目录 1、聘用外部DevOps顾问 2、建立DevOps共识 3、采用“DevOps改进”而非“DevOps转型” 4、构建“比学赶超”的组织氛围 5、规范化DevOps实践 1、聘用外部DevOps顾问 小型团队可以不用聘用昂贵的外部教练,因…

DevOps

DevOps 一、DevOps的由来和概念1. 由来2. DevOps概念解析(1)来自不同渠道和来源的定义:(2)其他摘录 二、DevOps 工作流程1. DevOps的好处与价值2. DevOps能力环 三、devops流程工具四、DevOps发展现状哪些互联网公司采…