- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我已经学习了一半以上的汇编,并且熟悉有符号和无符号整数如何以位表示的概念,我知道这似乎是一个奇怪的问题,答案很明显,但我我想知道对一对数字(其中一个被认为是有符号的,而另一个被认为是无符号的)使用加法之类的算术运算是否有意义,我想过如下多个示例,它们将产生正确的结果:
10000001(1 字节整数,视为无符号,相当于 129)
+
11111111(1 字节整数并被视为有符号(二进制补码系统),相当于 -1)
10000000(1 字节整数,在无符号逻辑中等于 128)
现在,如果上限值在 AL 寄存器中,并且我们有以下指令代码(GAS 格式):
addb -1, %al
最佳答案
从数学上讲,您不会添加有符号或无符号数字。只有模 232 的值(假设您有 32 位寄存器)。这些值涵盖了 232 个连续整数的范围,但您可以自由地将该范围解释为几乎从任何地方开始。 “Signed”和“unsigned”就是这样的两种解释。
换句话说,对于 4 位寄存器,“1011”的无符号解释为 11,而有符号解释为负 5。但只有一个值(数学家通常称之为“11 模 24”,因为数学家传统上喜欢无符号解释)。例如,如果您将“0110”添加到该值(在有符号和无符号解释中都是“6”),那么您会得到“0001”,这是正确的值:减五加六产生一,加十一次6 是 17,它在减少模 24 时也等于 1(17 是 1 加 16;“减少模 24”是关于除以 16 [即 24] 并只保留余数)。
另一种说法如下:数值的(二进制)位数在概念上向左是无限的。 CPU 寄存器只保留最右边的 32 位。无符号解释通常假设所有最左边的位都为零。签名解释是关于假设,传统上,所有最左边的位都具有与位 31 相同的值(即全部为零,或全部为 1)。无论哪种方式,当您执行加法(或减法或乘法)时,进位是从右向左传播,而不是相反,因此这些被忽略位的值对 32 位结果没有任何影响。所以只有一个“加”操作码,它一点也不关心它的操作数在程序员的大脑中是“有符号”还是“无符号”。
在执行与模算术不兼容的运算时,必须考虑有符号性。转换成十进制数字序列进行显示就是这样一种操作。然而,更常见的情况是比较。取模 232 的值未排序;它们处于一种循环循环中(当您将 1 添加到 232-1 并减少模 232 时,您会返回到 0)。仅当您考虑整个整数范围内的整数时,比较才有意义。此时,您必须决定是使用签名解释还是未签名解释。这就是为什么 x86 处理器同时提供 jg
(如果更大则跳转,签名解释)和 ja
(如果高于,则跳转,未签名的解释)。
关于assembly - 对一对有符号和无符号数字进行算术运算是否合法?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/4645230/
(注意:这个问题的动机是试图提出预处理器黑客来生成无操作分配来回答另一个问题: Macro that accept new object ...请记住这一点!) 这是一个人为的类: class foo
所以我尝试用java编写一个井字棋游戏。大部分已经完成,但是,如果有人选择了已被占用的空间,我无法返回无效的移动。 这是我试图弄清楚的代码。我认为由于空间是由数字 0 表示的(我的教授告诉我们这一点)
我想使用 Java 代码获取某些 Google 搜索引擎查询(在整个网络上)的估计结果数。 我每天只需要做很少的查询,所以一开始 Google Web Search API ,虽然已被弃用,但似乎已经
C++ Primer, 5e 的练习 4.20 询问表达式 iter++->empty(); 是否成立是合法的。假设iter是 vector::iterator . 这个表达式是合法的。我用gcc编译
C++ Primer, 5e 的练习 4.20 询问表达式 iter++->empty(); 是否成立是合法的。假设iter是 vector::iterator . 这个表达式是合法的。我用gcc编译
在 C++ 中,动态内存(取消)分配(malloc-free/new-delete)显然可以重复获得相同的内存范围,该内存范围被释放并按顺序再次分配。在多线程 C++ 中,这可能发生在多个线程中。 显
AesCryptoServiceProvider.LegalKeySizes 字段显示允许的位大小。 但是我不明白的是,如果这些都是真的,我如何才能成功利用 2048 位 key 长度(256 字节)
我有一个结构: typedef struct _n { int type; union { char *s; int i; }; } n; 当我
这个问题在这里已经有了答案: 关闭10年前. Possible Duplicate: int var = 1; void main() { int i = i; } 以下代码在g++和Visual C
根据 C++03 标准 (5.3.4/7): When the value of the expression in a direct-new-declarator is zero, the allo
我正在尝试创建一个生成器,使用 scalacheck 1.6.6 和规范 1.7 (scala 2.8.1) 生成(非零长度)合法的 unicode 字符串。 我希望我可以创建像这样的生成器: obj
这确实是一个关于 C++ 的问题,而不是 OpenGL。我正在关注 this OpenGL 教程(我刚开始),作者使用 C++(不是 C)。我的问题是 glVertexAttribPointer ta
由于 C++ 别名规则,您不能随意将 (一个 int*) 指向 char 数组,这似乎达成了一些共识。 从另一个问题——Generic char[] based storage and avoidin
我正在寻找一个通过 HTTP 接口(interface)发送文本消息的 SMS 网关。 但是,有些短信网关不允许设置发件人ID,允许的要么要求用户证明发件人ID是自己的手机号码,要么手动检查每个发件人
我们注意到您的应用要求用户注册个人信息才能访问非基于帐户的功能。在允许访问与用户无关的应用内容和功能之前,应用不能要求用户注册。 我们在注册时采用电子邮件 ID,因为所有数据都代表电子邮件 ID 在后
我一直在阅读 Bloch 和 Gafter 的 Java Puzzlers,并读到了第 10 个谜题 (Tweedledee)。这个谜题的本质是 provide declarations for th
这个问题确实符合标题:我很想知道造成这种差异的技术原因是什么,以及基本原理? std::shared_ptr sharedToVoid; // legal; std::unique_ptr uniqu
我试图做的是将数据框数据附加到现有的合法 excel 文件中。我使用了 openpyxl 中的 load_workbook() 函数,但它系统地返回了一个错误。这是一些在我的机器上崩溃的代码: fro
App 多次被 Apple 拒绝 “经过进一步审查,我们仍然发现您的应用使用了后台定位服务,但并未按照 iOS 人机界面指南的要求在位置模式警报中阐明其使用目的。” 在“NSLocationAlway
据我所知,像这样在 C++ 中实例化一个整数是合法的: int x = int(5); 作为一名 Java 程序员,我会假设这行代码调用传递“5”作为参数的整数的构造函数。我读到 int 不是一个类,
我是一名优秀的程序员,十分优秀!