Online Compiler Nasm

extern scanf, printf section .data format_str db "%s ", 0 format_int db "%d ", 0 section .bss s1 resd 201 s2 resd 201 len1 resd 4 len2 resd 4 sptr resd 4 sless resd 4 spref resd 400 section .text global main main: mov ebp, esp ; for correct debugging push s1 push format_str call scanf add esp, 8 push s2 push format_str call scanf add esp, 8 xor ecx, ecx .len1_start: mov eax, dword [s1 + ecx] test eax, eax jz .len1_end inc ecx jmp .len1_start .len1_end: mov dword [len1], ecx xor ecx, ecx .len2_start: mov eax, dword [s2 + ecx] test eax, eax jz .len2_end inc ecx jmp .len2_start .len2_end: mov dword [len2], ecx mov eax, dword [len1] mov ebx, dword [len2] .if: cmp eax, ebx jl .else mov dword [sptr], s1 mov dword [sless], s2 jmp .endif .else: mov dword [sptr], s2 mov dword [sless], s1 mov eax, dword [len1] mov ebx, dword [len2] mov dword [len1], ebx mov dword [len2], eax .endif: ; На этом фрагменте код выдаёт nasm: error: write error on output file `main.o' mov ebx, dword [sptr] add ebx, dword [len1] mov byte [ebx], '#' inc ebx mov edx, [sless] mov al, [edx] mov byte [ebx], al xor ecx, ecx .merge_loop: inc ecx mov al, byte [edx + ecx] mov byte [ebx + ecx], al test al, al jnz .merge_loop ; На этом фрагменте код выдаёт nasm: error: write error on output file `main.o' push dword [len1] push format_int call printf add esp, 8 xor eax, eax ret
Вот разбор твоего кода:

1) **Что делает код:**  
Программа считывает две строки (`s1` и `s2`), вычисляет их длины (в символах, считая по 4 байта за раз — это ошибка), затем сравнивает длины и пытается выполнить слияние строк: к более длинной строке дописывается символ `#`, затем посимвольно добавляется более короткая строка. После этого выводится длина первой строки (в исходном виде, без учёта перестановки). Код падает на этапе сборки с ошибкой записи в объектный файл.

2) **Конкретные подсказки:**  
- Ошибка `nasm: error: write error on output file` обычно возникает из-за синтаксической ошибки в ассемблерной инструкции. Проверь строки с `mov byte [ebx], '#'` и `mov byte [ebx + ecx], al` — возможно, ты используешь недопустимый режим адресации или забыл указать размер операнда в одной из команд.  
- Также обрати внимание, что ты измеряешь длину строки как количество **dword** (4-байтовых слов), а не байтов. Для строк символов нужно использовать `byte` при проверке на нуль-терминатор, иначе длина будет в 4 раза меньше реальной.