我正在尝试创建一个汇编程序,它接受用户输入的不超过 4 位的十六进制数,并以 10 为基数输出相同的数字。这是在 Linux 安装上使用 NASM 完成的。使用我找到的一些教程和我对这种语言的非常有限的理解,我想出了这个。
section .data
inp_buf: times 6 db 0
numPrompt: db "Enter a hexadecimal value no greater than 4 digits: "
len1 equ $ - numPrompt
answerText: db "The decimal value is: "
len2 equ $ - answerText
section .bss
dec: resb 5
section .text
global _start
_start:
mov edx, len1
mov ecx, numPrompt
mov ebx, 1
mov eax, 4
int 0x80
mov eax, 3
mov ebx, 0
mov ecx, inp_buf
mov edx, 6
int 0x80
mov esi, dec+11
mov byte[esi], 0xa
mov eax, ecx ;I feel like the problem must be here
mov ebx, 0xa
mov ecx, 1
next:
inc ecx
xor edx, edx
div ebx
add edx, 0x30
dec esi
mov [esi], dl
cmp eax, 0
jnz next
mov edx, len2
mov ecx, answerText
mov ebx, 1
mov eax, 4
int 0x80
mov edx, ecx
mov ecx, esi
mov ebx, 1
mov eax, 4
int 0x80
mov ebx, 0
mov eax, 1
int 0x80
应该注意的是,如果用户输入被忽略,而您只是在数据部分放入一个带有十六进制的变量,程序可以毫无问题地转换它。例如,如果您有 hexNum: equ 0xFFFF
行并将上面的注释行替换为 mov eax, hexNum
那么代码能够正确地将其转换为基数 10 .错误必须与用户输入的格式有关,但我不知道如何验证。
我很感激任何关于我的问题的见解。这是我除了“hello world”之外的第一个汇编程序,其中很多新概念对我来说仍然令人困惑和难以理解。如果我有更好或更简单的方法来完成整个程序,那么我也很想听听。谢谢!
最佳答案
`inp_buffer 中的值将采用十六进制格式,例如。
1234
将被存储为
0x31 0x32 0x33 0x34
在 4 个连续字节中。
必须使用与反向转换完全相反的过程将数字从 ascii 格式转换为十六进制格式。
将数字转化为十六进制后,转十进制的过程是正确的,可以说是小数点。
我建议首先完全转换,然后逐字节转换为 ascii。得到最终结果然后进行转换总是更好,尤其是在难以调试的汇编语言编程中。
关于linux - 在汇编中将用户输入的十六进制转换为十进制,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/36877407/