struct str { int a; int b; int c; int d; int f; int g; }; // 结构体声明
struct str getStr(int a, int b, int c, int d, int f, int g){ // 函数实现
// //24字节开辟堆空间!
// struct str * str1 = malloc(24);
struct str str1;
str1.a= a;
str1.b= b;
str1.c= c;
str1.d= d;
str1.f= f;
str1.g= g;
returnstr1;
}
调用函数struct str str2 = getStr(1, 2, 3, 4, 5, 6);
data:image/s3,"s3://crabby-images/5d080/5d0803d0e6287014b97ec0c0dda41b5656d28fb6" alt=""
x8寄存器指向sp+#0x8的地址,为了给getStr函数操作这个寄存器(夸栈操作)
data:image/s3,"s3://crabby-images/d511b/d511bce615873f70107cb01973b637f9f016db15" alt=""
然后我们可以验证一下我们分析的对不对,我们查看一下X8寄存器的地址x8 = 0x000000016f258ee8,po一下这个地址是6159699688,对应到数据如图,正好跟我们分析的一样,将1,2,3,4,5,6以X8寄存器为基准,每1个字节放数据。
data:image/s3,"s3://crabby-images/98a8a/98a8a7f005de43b6cd3da2238d464b447b37c9e7" alt=""
所以我们可以断定X8的地址应该是str2变量指向的地址空间,在getStr函数调用时,完成入栈操作。
以上是个人看法,不对的地方,欢迎大佬指正。
data:image/s3,"s3://crabby-images/3b553/3b55371a73edc395c610c3f6de98a28eb86dfaf8" alt=""
网友评论