今天看了關(guān)于 macOS 下 C++ 數(shù)組初始化的反匯編代碼橄仍,使用 HT Editor 已經(jīng)看不懂了怠惶,因此下載了 Hopper Disassembler 來進行反匯編查看酬凳。
C++ 代碼
#include <iostream>
using namespace std;
int main()
{
int a[10] = {1, 2, 3, 4, 5, 6, 7, 8, 9, 10};
int i, j;
for (i = 0; i < 10; i ++)
{
cout << a[i] << " ";
}
cout << endl;
int b[2][2] = {1, 2, 3, 4};
for (i = 0; i < 2; i ++)
{
for (j = 0; j < 2; j ++)
{
cout << b[i][j] << " ";
}
cout << endl;
}
return 0;
}
代碼比較簡單取募,在定義數(shù)組的時候直接就初始化了數(shù)組壮吩,然后我通過 HT Editor 查看了很久不皆,沒有搞明白它是如何初始化的贯城,然后就是用了 Hopper 進行查看,然后就明白了霹娄。
Hopper 中的反匯編代碼
使用 Hopper 查看就非常的明顯了能犯,在地址 100000ef3 的位置處調(diào)用了 memcpy 函數(shù),來進行了內(nèi)存的拷貝项棠,rcx 是目的內(nèi)存的開始地址悲雳,rax 里面保存著常量。
0000000100000ec8 lea rax, qword [0x100001f20]
0000000100000ecf mov rcx, qword [___stack_chk_guard_100002018]
0000000100000ed6 mov rcx, qword [rcx]
0000000100000ed9 mov qword [rbp+var_8], rcx
0000000100000edd mov dword [rbp+var_44], 0x0
0000000100000ee4 lea rcx, qword [rbp+var_30]
0000000100000ee8 mov rdi, rcx ; argument "dst" for method imp___stubs__memcpy
0000000100000eeb mov rsi, rax ; argument "src" for method imp___stubs__memcpy
0000000100000eee mov edx, 0x28 ; argument "n" for method imp___stubs__memcpy
0000000100000ef3 call imp___stubs__memcpy
在 HT Editor 中無法顯示 memcpy 香追,因此看不懂合瓢。真是工欲善其事,必先利其器啊透典。
今天看這部分花的時間不少晴楔,現(xiàn)在也不知道 Hopper 激活了沒顿苇,按照網(wǎng)上的教程操作了,但是每次啟動時税弃,還是會要求輸入 lisence 纪岁。郁悶的!