- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
维基百科指出:
High-level assemblers in computing are assemblers for assembly language that incorporate features found in high-level programming languages.
接着说:
High-level assemblers typically provide instructions that directly assemble one-to-one into low-level machine code as in any assembler, plus control statements such as IF, WHILE, REPEAT...UNTIL, and FOR, macros, and other enhancements.
最后是指一些高级汇编器:
More recent high-level assemblers are Borland's TASM, NASM, Microsoft's MASM, IBM's HLASM (for z/Architecture systems), Alessandro Ghignola's Linoleum and Ziron.
其中,我只用过 NASM,但我能理解为什么它是高级汇编程序;它通常具有结构、宏和非常广泛的预处理器。但是,当我看到 FASM 的维基百科页面时,它把 FASM 称为低级汇编程序,我并没有真正理解。 FASM不仅支持结构体和宏(我对预处理器了解不多),还支持asssemble-time if语句。是否有任何其他规则指定汇编程序是高级还是低级? FASM 维基百科页面表示它有意不支持许多命令行选项,但仅凭这一点就可以使它成为低级汇编程序吗?
最佳答案
NASM 具有不错的宏功能,但它不像 MASM 那样内置了 .IF、.WHILE、.REPEAT...UNTIL 和 .FOR 指令等废话。 MASM 太老了,以至于有些人宁愿使用高级语言也不得不用 asm 编写。 NASM 是最近才设计的,如果您需要,只需使用编译器即可优化,而不是天真地为 MASM 填写模板 .IF
指令。
我不会称 NASM 为“高级”汇编程序。
虽然这些术语没有具体的技术含义,只是一种软性设计目标/ self 宣传语言。 FASM 本身是用 asm 编写的,并且肯定会美化它是多么精简和小巧。我认为称自己为“低级”汇编器是为了声明“我们故意不是 MASM”;我们为您提供的工具可用于真正编写 asm,而不是假装是一种高级语言。
MASM/TASM 也有“变量” - foo dd 123
不仅将 foo
定义为一个符号,还在其他指令中使用 foo
add foo, 1
表示这些指令的操作数大小。 NASM 和 FASM 没有任何像这样奇怪的东西:你可以查看源代码行并知道它是如何组装的,而无需查看其他地方来确定 foo
是否是 equ
常量或符号。
IMO,NASM 是一个不错的宏汇编程序,仅此而已。它并不比 FASM 任何“更高级别”。 NASM 在“高级”汇编程序列表中似乎非常不合适。
关于assembly - FASM 是低级汇编器而 NASM 是高级汇编器吗?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/66133054/
某些 AMD64/x86 命令需要立即值作为操作数(例如 imm8)。是否可以使用存储在某个寄存器中的值(例如 ah)来代替这个硬编码值? 例如: 如果我想移动 xmm 寄存器,可以使用 pslldq
您好,我正在修改汇编级编程。我有以下代码 mov al, 'H' call my_function my_function: mov ah,0x0e ;
x86 汇编程序例程通常以以下序言开始: push ebp ; Save ebp mov ebp, esp ; Set
这个问题已经有答案了: What is the purpose of XORing a register with itself? [duplicate] (7 个回答) 已关闭 2 年前。 我们有时
如果您不了解二进制,我知道 BCD 是更直观的数据类型。但我不知道为什么要使用这种编码,它好像没有多大意义,因为它浪费以 4 位表示(当表示大于 9 时)。 另外,我认为 x86 仅支持直接添加和替换
x86 汇编程序例程通常以以下序言开始: push ebp ; Save ebp mov ebp, esp ; Set
var a int[1]; var aa int[1]; aa = a; 假设我们想在 java jvm 中编译这样的东西。看起来人们只会做一个 ldc 1 newarray int astor
是否有任何编写 MIPS 汇编器的引用指南或教程? 最佳答案 如果您希望实际编写汇编程序,您需要知道您正在编写的平台的可执行文件的格式(例如 ELF ),那么您需要使用 MIPS instructio
我想写一个简单的 M.A.R.I.E.计算表达式 A x B + C x D 的程序. 现在,关于 Marie 汇编语言的信息并不多。我不确定是否有乘法?如果没有,我是否必须循环或其他东西才能使其成倍
我想知道为 NASM 编写汇编代码的格式是什么。有什么地方教的吗?我尝试在 NASM 上运行 MASM32 文件,但我认为它无法识别指令。 最佳答案 总是有 the manual . 关于linux
我想要的是类似 g++ 的东西,我可以在其中输入: compiler_name my_assembly_code.extention ...并让它编译我的汇编代码。它是 32 位还是 64 位并不重要
我正在为 8086 开发一个汇编程序。我的问题是如何将十六进制操作码转换为可执行文件,如 .EXE、.ELF、.COM、a.out 等。为此寻找链接/资源,汇编程序应该执行链接过程还是由操作系统自动?
我想编写 64 位 Windows 程序集(最好使用 NASM)。我在谷歌上看起来很不错,但似乎找不到 64 位 Windows 编译器。一些站点提到了 ml64,但它似乎不再包含在 VC++ 中。我
使用 GNU Binutils 声明汇编代码时,例如: .long MY_Label .long MY_Second_label 即使操作码和其他信息在地址空间中将它们分开,也可以在进行十六进制转储时
似乎单元测试这些天变得风靡一时,我知道你们中的许多人会想:“那么为什么不直接使用语言 X 和框架 Y 呢?”但我提出这个想法更多是为了证明概念,或者是出于对我早年计算机编程的怀念。 我正在研究使用 N
作为编译器项目的一部分,我必须为 x86 编写 GNU 汇编器代码来比较浮点值。我试图找到有关如何在线执行此操作的资源,据我了解,它的工作原理如下: 假设我要比较的两个值是浮点堆栈上的唯一值,则 fc
操作系统:Windows 10 CPU:英特尔酷睿 i5-5300U 架构:x64 我刚刚开始学习汇编语言。我使用了在线编译器,但今天我下载了NASM。我尝试编写这个将 10 乘以 15 的简单代码:
查看以下代码: (ebp-0x8 -> int) (ebp-0x4 -> int*) => 0x80483f3 : mov DWORD PTR [ebp-0x8],0x0 0x80483
我需要编写一个类似 CorFlags 的应用程序。如果我有程序集文件的路径,我该如何读取它的 CorFlags? 我特别需要知道程序集是 Any-CPU 还是仅 x86 我想避免使用反射加载程序集,因
查看以下代码: (ebp-0x8 -> int) (ebp-0x4 -> int*) => 0x80483f3 : mov DWORD PTR [ebp-0x8],0x0 0x80483
我是一名优秀的程序员,十分优秀!