csapp2e 家庭作业 3.66

时间:2022-02-06 21:54:16

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行。