4
mov eax, ptr_to_num1 ; little endian
mov ebx, ptr_to_num2 ; little endian
xor ecx, ecx
xor edx, edx
clc
bytes_addition:
    mov dl, byte [eax+ecx] ; byte from shortest
    adc dl, byte [ebx+ecx]
    mov byte [eax+ecx], dl
    inc ecx
    cmp ecx, 4 ; counter, 
    jl bytes_addition

考虑在

EAX:4F2252FF(大端)

EBX:00DFFC00(大端)

这个加法的结果是错误的:50024fff(大端)。它应该是 50024eff。看起来进位标志受到了影响,但为什么呢?

4

1 回答 1

6

cmp影响进位,这就是它用于无符号比较的方式。

您可以从ecx-4 开始,然后使用jnz bytes_addition. 你已经有了inc那里,它会在变为零时设置零标志ecx,并且不会影响进位。

当然,必须通过eax在循环之前添加 4 或在寻址中添加 4 来补偿此偏移量。

于 2015-12-13T21:45:08.017 回答