アセンブラーで整数を出力する方法を探しています (私が使用しているコンパイラーは Linux の NASM です) が、いくつかの調査を行った後、本当に実行可能な解決策を見つけることができませんでした。この目的に役立つ基本的なアルゴリズムの説明を見つけることができ、それに基づいて次のコードを開発しました。
global _start
section .bss
digit: resb 16
count: resb 16
i: resb 16
section .data
section .text
_start:
mov dword[i], 108eh ; i = 4238
mov dword[count], 1
L01:
mov eax, dword[i]
cdq
mov ecx, 0Ah
div ecx
mov dword[digit], edx
add dword[digit], 30h ; add 48 to digit to make it an ASCII char
call write_digit
inc dword[count]
mov eax, dword[i]
cdq
mov ecx, 0Ah
div ecx
mov dword[i], eax
cmp dword[i], 0Ah
jg L01
add dword[i], 48 ; add 48 to i to make it an ASCII char
mov eax, 4 ; system call #4 = sys_write
mov ebx, 1 ; file descriptor 1 = stdout
mov ecx, i ; store *address* of i into ecx
mov edx, 16 ; byte size of 16
int 80h
jmp exit
exit:
mov eax, 01h ; exit()
xor ebx, ebx ; errno
int 80h
write_digit:
mov eax, 4 ; system call #4 = sys_write
mov ebx, 1 ; file descriptor 1 = stdout
mov ecx, digit ; store *address* of digit into ecx
mov edx, 16 ; byte size of 16
int 80h
ret
私が達成したいもののC#バージョン(明確にするため):
static string int2string(int i)
{
Stack<char> stack = new Stack<char>();
string s = "";
do
{
stack.Push((char)((i % 10) + 48));
i = i / 10;
} while (i > 10);
stack.Push((char)(i + 48));
foreach (char c in stack)
{
s += c;
}
return s;
}
問題は、文字を逆に出力することです。そのため4238
、出力は8324
. 最初は、x86スタックを使用してこの問題を解決し、数字を押し込んでポップアウトし、最後に出力できると思っていましたが、その機能を実装しようとすると失敗し、取得できなくなりました出力。
その結果、整数を出力するという目標を達成するために、このアルゴリズムにスタックを実装する方法について少し当惑しています。利用可能な場合は、よりシンプルで優れたソリューションにも興味があります (これは私の最初のアセンブラー プログラムの 1 つであるため)。