如何在MASM中访问二维数组

时间:2015-01-07 17:07:35

标签: arrays loops assembly x86 masm

你能告诉我如何在MASM中访问两个dimmensional数组吗?

C ++代码:

int k = 0
    for (i = 0; i<5; ++i)
    {
        if (k == text.length())break;
        for (j = 0; j<2; ++j)
        {
            for (t = 0; t<26; ++t)
            {
                if (text[k] == letters[t]){ tab[i][j] = t; k++; break; }
            }
        }
    }

MASM

mov al, [ebx]       ;ebx - begin of text array          
xor esi, esi        
for1:
cmp al, 00                  
je break_for1                   
mov j, 0        
for2:
mov t, 0                    
mov ecx, adrAlphabet        ;ecx - begin of letters array           
for3:               
;if (text[k] == letters[t]){ tab[i][j] = t; k++; break; }
mov ah, [ecx]               
cmp ah, 00                      
je end_of_alphabet              
cmp al, 00                      
je end_of_text                  
cmp al, ah                          
jne not_equal
;here comes the problem
        mov edx, t                      
        mov [letters + (esi*4 + j)*4], edx
;   
inc k                           
inc ebx                         
jmp break_t                 
; end if
not_equal:
inc ecx                         
inc t                       
cmp t, 26                       
jne for3

break_t:
inc j                           
cmp j, 2                    
jne for2

inc esi                             
cmp esi, 5                      
jne for1

break_for1:
end

这只是我代码的一部分,但我只想了解数组。 你能给出一些如何在MASM中使用tab [i] [j]的例子吗? 另一个问题是,我如何修改标签数组的长度?简而言之:在程序开始时,将计算标签大小,然后我想设置数组大小。

由于

1 个答案:

答案 0 :(得分:-2)

C ++标准保证大小为[a][b]的二维数组等同于大小为[a*b]的单个一维数组。 您可以不再将其视为二维数组,只需将其视为普通数组,而只是连续的数据块。

也就是说,如果您想访问tab[i][j],则与访问tab+a*i+j

完全相同

如果您知道a(我们数组中的行数)总是2,4或8,您可以直接使用表单

mov byte ptr [eax*8+ecx], someValue

我是eax,j是ecx。

否则你必须手动计算i*a+j,使用shift或imul并将其用作数组的索引。

例如:

; Write 0 at tab[i][j]
; We use EDX because of how IMUL works
mov edx, i ; EDX = i
imul a ; EDX = i*a
add edx, j ; EDX = i*a+j
add edx, offset tab ; EDX = tab[i*a+j] = tab+i*a+j
mov byte ptr [edx], 0