注册 登录
编程论坛 汇编论坛

怎么把它变成偏移量的那种,而不是直接来个数组下标?

后卿 发布于 2023-03-30 15:04, 2180 次点击
怎么把它变成偏移量的那种,而不是直接来个数组下标?

程序代码:
a[1] = 5;
009B1519  mov         eax,4  
009B151E  shl         eax,0  
009B1521  mov         dword ptr a[eax],5  
    a[2] = 5;
009B1529  mov         ecx,4  
009B152E  shl         ecx,1  
009B1530  mov         dword ptr a[ecx],5  

这是我现在的汇编代码
怎么把它变成下面的 代码呢
程序代码:
a[1] = 5;
009B1519     mov         eax,4  
009B151E  shl         eax,0  
009B1521  mov         dword ptr [ebp+eax-1ch  ],  5  
a[2] = 5;
009B1529  mov         ecx,4  
009B152E  shl         ecx,1  
009B1530  mov         dword ptr  [ebp+ecx-1ch  ],5  


就是把它变成偏移量的那种,而不是直接来个下标
这两个都是我在VS反汇编里打开的样子
3 回复
#2
后卿2023-03-30 15:13
我知道这样多次一举,但是我也是想把这个写给别人看的
#3
lliu_20062023-11-06 09:42
回复 楼主 后卿
这两个的区别:
前者是函数外部全局声明的数组;
后者是函数内局部声明的数组。
#4
YUNk2024-11-12 19:31
在vs里面你开启不同的优化后反汇编的结果页不一样吧。这里用偏移做到一模一样的话有点麻烦。    int a[5] = { 1,2,3,4,5 };
00644FB0  mov         dword ptr [a],1  
00644FB7  mov         dword ptr [ebp-18h],2  
00644FBE  mov         dword ptr [ebp-14h],3  
00644FC5  mov         dword ptr [ebp-10h],4  
00644FCC  mov         dword ptr [ebp-0Ch],5  
    int bb = 12;
00644FD3  mov         dword ptr [bb],0Ch  
    int* pa = &a[0];
00644FDA  mov         eax,4  
00644FDF  imul        ecx,eax,0  
00644FE2  lea         edx,a[ecx]  
00644FE6  mov         dword ptr [pa],edx  
    int** ppa = &pa;
00644FE9  lea         eax,[pa]  
00644FEC  mov         dword ptr [ppa],eax  
    *(pa + 1) = 6;
00644FEF  mov         eax,dword ptr [pa]  
00644FF2  mov         dword ptr [eax+4],6  
    *(pa + 2) = 6;
00644FF9  mov         eax,dword ptr [pa]  
00644FFC  mov         dword ptr [eax+8],6  
不知道这样子算不算。但是做到跟图中一样是[eax+ecx-01ch],5   编译器优化是个问题,即使是禁止优化但是也不能做到完全禁止。
1