A CNT=7
B struct a_struct{
int idx;
int x[6];
}
下面是简单的分析
5 i -->eax
6 bp -->ecx
7 28i-->ebx
8 8i-->edx
9 7i-->edx
10*(28i+bp+4)+7i-->edx 对于C中第10行,我觉得这一行有点难理解,*(28i+bp+4)是直接计算出了ap->idx的值,因为a_struct只包含7个int值,所以加7i,就计算出了ap->x[ap->idx]距离a[CNT]的起始地址有多少个int
11 *(bp+0xc8)-->eax
12 *bp+*(bp+0xc8) -->eax 对应C第9行
13 eax-->*(edx*4+bp+8) 对应C第11行。