- iOS/Objective-C 元类和类别
- objective-c - -1001 错误,当 NSURLSession 通过 httpproxy 和/etc/hosts
- java - 使用网络类获取 url 地址
- ios - 推送通知中不播放声音
如何使用多寄存器处理大数?
假设您需要对无法放入 32 位寄存器的大数进行一些计算,并且解决问题的唯一方法是使用寄存器,内存解决方案不可用
比如乘法和偏差:
我们有 edx:eax
是否有一种方法或算法或指令可以将您的值直接放入 reg1:reg2:reg3...regn
中?
如果你在内存中有dq
,如果可能的话,如何将它存储在一个 32 位的两个寄存器中
最佳答案
旧的 8080 和 Z80 CPU 直接支持多寄存器操作,尽管只有预先选择的寄存器对,就像 Z80 有 8 位寄存器 a, b, c, d, e, h , l
和像 add hl,de
这样的指令使用 16b 对操作(但是例如这个 16b add
不更新标志,与 8 位 add d,e
等,它们比 8 位变体慢一些,因此使用 16 位值仍然会有一些损失,尽管通常 16b 对比仅使用 8 位指令编写的相同任务更有效.
8080 的这个特性是对 8086 ah:al = ax
的启发(我猜,没有事实) 8b 寄存器形成 16b 寄存器并且指令不仅与 8 一起运行位寄存器,但也与预选对。尽管 8086 更像是原生 16b CPU,因此此功能更像是“支持将 16b 寄存器分解为 8b,以便更轻松地迁移 8b 软件”,而不是“支持配对两个 8b 寄存器以进行 16b 数学运算”。
在 80386 之后,这种做法被放弃了,a
寄存器的 32 位扩展名为 eax
并没有为高 16b 部分添加新的别名,这使得它变得更难单独访问它(低 16b 是原始 ax
的别名,这是与 8086/186/286 任何方式向后兼容所必需的)。
因为 eax, ebx, ...
上半部分的那些额外的 16b 寄存器会大大增加寄存器的数量,使得旧的指令编码不再可行,实际上与性质在 x86 指令集中,保持基本指令的长度大多为 2 个字节是相当困难的,额外的组合可能会将平均值提高到 3 个字节。
现在您支持更多多寄存器组合的想法会更多更快地爆炸所需的操作码,因此这样的 ISA 平均每条指令可能需要大约 4-6 个字节。
虽然基本上花了很长一段时间人们才开始感到受到 16b 数学的严重限制(从 0 到 65535 的值在我看来确实很多,回到我用 Z80 CPU 在 ZX Spectrum 上做一些程序的时候),而 32b 是真正的突破,甚至是大多数现实生活中的人类数学任务,如商店价格等。可以很容易地用 32b 整数完成。又花了十年多的时间才更频繁地达到这个限制(不仅仅是在特殊情况下),比如当整部电影确实开始在磁盘上编码时,磁盘的大小通常超过千兆字节。
因此,通常根本不需要您提出的要求(今天的 64b 选项进一步插入了它,它涵盖了疯狂的值范围),并且当最终需要它时,从单独的指令构建它非常简单。 .. 例如 80386+ 代码添加 eax:ebx:ecx
和 esi:edi:edx
:
; eax:ebx:ecx += esi:edi:edx (96b integer addition)
add ecx, edx
adc ebx, edi
adc eax, esi
简单到不能证明上面提到的将这样的东西直接放入 CPU 的操作码大小爆炸是合理的。
关于algorithm - 使用多寄存器处理大量数据,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/49181818/
我无法理解如何使用一些旧的 VGA 代码在这个示例中设置序列 Controller 寄存器: mov dx,SC_INDEX mov ax,0604h out dx,ax
我希望对 zmm 0-31 寄存器集的四字元素执行整数算术运算并保留这些运算产生的进位位。看来这只有在通用寄存器集中处理数据时才有可能。 因此,我想将信息从 zmm 0-31 寄存器之一复制到通用寄存
ARM 64中包含多种寄存器,下面介绍一些常见的寄存器。 1 通用寄存器 ARM 64包含31个64bit寄存器,记为X0~X30。 每一个通用寄存器,它的低32bit都可以被访问,记为W0~W
1.寄存器 组合逻辑存在一个最大的缺点就是存在竞争与冒险,系统会产生不定态;使用时序逻辑电路就会极大的改善这种情况 寄存器具有存储功能,一般是由D触发器构成,由时钟脉冲控制,每个D触发器能够
使用 $gp 是否存在危险?注册以存储值?我想我的问题是 $gp 的真正功能是什么?它是否以某种方式在幕后调用,以便如果我使用它,事情可能会变得非常非常错误? 最佳答案 那么,$gp register
我遇到了这段代码的问题,我无法弄清楚问题出在哪里。所以当我运行这段代码时:if $row["count"] > 0 else块运行和 $_SESSION["error"]设置。 当$row["coun
所以我正在做二进制炸弹的变体。这就是阶段 0x0000000000401205 : sub $0x8,%rsp 0x0000000000401209 : cmp $0x3,
我在一个名为 (EmployeeDetailKey - varchar(10)) 的字段中获得了一个值,其中包含顺序值,例如 00001, 00002, 00003.... 它位于 Employeed
我有一个要求,应该为每个调用的线程分配一个计数器变量。但我没有得到预期的结果,实际上计数器在线程中重复。我创建了一个虚拟表和一个过程来将计数器值插入到表中。无论如何,是否可以更改代码以便线程获得递增的
预期输出:需要打印第4季度的wage_amt +--------------+--------------+--------------+--------------+ | wages_amt_q1
如何匹配模式 abc_[someArbitaryStringHere]_xyz? 为了澄清,我希望正则表达式能够匹配以下性质的字符串: abc_xyz、abc_asdfsdf_xyz、abc_32rw
从下拉列表(自定义)中选择一个值而不是常规下拉列表,它有很多下拉值 我可以用代码选择第一个值 find('.selected', :text=>arg1,exact: false).click 但无法
这个问题不太可能帮助任何 future 的访问者;它只与一个小的地理区域、一个特定的时间点或一个非常狭窄的情况有关,这些情况并不普遍适用于互联网的全局受众。为了帮助使这个问题更广泛地适用,visit
我有 .csv 文件中的数据,它包含 2 列 x 轴和 y 轴。从 .csv 文件读取轴,然后使用拉伸(stretch)指数函数拟合数据,但显示错误。 这里我给出示例数据以方便理解。 我的函数是f(x
我正在尝试使用以下汇编代码将磁盘扇区加载到内存中,但正如我在终端中使用一些 int 0x10 时发现的那样,它不起作用的原因是它陷入了无限循环。我以为循环会自动为我递减 cx 寄存器。下面是代码,其中
我正在尝试编写一个脚本,该脚本将在 vim 中打开一个文件并将其中的特定行复制到 vim 的寄存器之一中。当脚本再次运行时,它会决定再次打开文件,然后将 vim 寄存器中的值粘贴回。实际上,脚本应该在
我目前正在尝试弄清楚如何将指针寄存器 SI 指向的内存中的第一个字节添加到 AX 寄存器的当前内容中。 因此,如果 SI 包含某个地址,并且该地址在内存中的值是:00 和 01,我希望将 00 添加到
我试图将两个 16 位数字与以下 NASM 代码相乘: mov ax, [input1] mov bx, [input2] mul bx 前面代码的结果存储在 DX:AX 我试图使用来自单独库“pri
我正在尝试修改 rip 寄存器(只是为了好玩)。 buffer 应该是内存地址,所以不知道为什么会得到Error: operand type mismatch for 'movq' #include
我可以告诉gcc-style inline assembly把我的__m512i变量到特定 zmm注册,如 zmm31 ? 最佳答案 就像在根本没有特定寄存器约束的目标(如 ARM)上一样,使用 lo
我是一名优秀的程序员,十分优秀!