// Array Access
%rdi = z
%rsi = digit
movl (%rdi,%rsi,4), %eax // z[digit]
mov 0x100(%rbx,%rax,4), %rax // x = b[x][y]
int get_digit(int z[5], int digit)
{
return z[digit];
}
addl $1, (%rdi,%rax,4) # z[i]++ // Increment the array
Multidimensional Arrays vs. MultiLevel Arrays
Multidimensional
A[R][C]
movel(A, I, K) // A = array, I = index, K = Bytes
A + i * (C * K) // start of each row where C is the elements in row
array[0][1] = ........0000 0001
array[0][2] = ........0000 0010
array[0][3] = ........0000 0011
data:image/s3,"s3://crabby-images/25193/2519345ea41729c30786faa2d823c9480dffa4ca" alt="Untitled"
data:image/s3,"s3://crabby-images/4ff3b/4ff3b8fc089afccf54d396e0a4fddd42b02e4874" alt="Untitled"
Finding the Functions
data:image/s3,"s3://crabby-images/85621/85621ed8762cb14a10004c8689f01185993e059b" alt="Untitled"
data:image/s3,"s3://crabby-images/13d17/13d178a9ea2cf4523087674a19d6f64f585f9c24" alt="Untitled"
- When doing this type of problem, when we access the array2(, rdx, 4) → we are looking for the number of columns which can give us an idea of what n is, same thing for m
Multilevel Array
data:image/s3,"s3://crabby-images/9c3e5/9c3e5076672dd8883f5424140b060786cc2dd833" alt="Untitled"
int myArr2[3]* // array of pointers to array
// Condsider this Array
int ∗my array [ 4 ] [ 3 ] ;
// Accessing from Above Array
My_array + x*3*8 + y*8
data:image/s3,"s3://crabby-images/8a89d/8a89d4b0a4af372b8c24a8f5670ab02d231d4324" alt="Untitled"
data:image/s3,"s3://crabby-images/7ae38/7ae38a6c036b45e0dbe6572a9df4a4dc67baeb4a" alt="Untitled"
data:image/s3,"s3://crabby-images/bd04e/bd04e44e06cfa15ffc4b81c80d5f4a9d6f87b395" alt="Untitled"