交流
商城
MCN
登入
注册
首页
提问
分享
讨论
建议
公告
动态
发表新帖
发表新帖
5 数组
分享
未结
0
638
李延
LV6
2022-06-07
悬赏:20积分
# 1 数组 ```c #include <stdio.h> int sum(int array[],int n) { int q = 0; while (n >= 0) { n--; q += array[n]; } return q; } int main() { int a[] = {1,2,3,4,5}; int num = sum(a,5); printf("sum is %d!\n", num); return 0; } ``` ```asm .file "array.c" .text .globl sum .type sum, @function sum: .LFB11: .cfi_startproc movl $0, %eax jmp .L2 .L3: subl $1, %esi movslq %esi, %rdx addl (%rdi,%rdx,4), %eax .L2: testl %esi, %esi jns .L3 rep ret .cfi_endproc .LFE11: .size sum, .-sum .section .rodata.str1.1,"aMS",@progbits,1 .LC0: .string "sum is %d!\n" .text .globl main .type main, @function main: .LFB12: .cfi_startproc subq $40, %rsp .cfi_def_cfa_offset 48 movl $1, (%rsp) movl $2, 4(%rsp) movl $3, 8(%rsp) movl $4, 12(%rsp) movl $5, 16(%rsp) movl $5, %esi movq %rsp, %rdi call sum movl %eax, %esi movl $.LC0, %edi movl $0, %eax call printf movl $0, %eax addq $40, %rsp .cfi_def_cfa_offset 8 ret .cfi_endproc .LFE12: .size main, .-main .ident "GCC: (GNU) 4.8.5 20150623 (Red Hat 4.8.5-44)" .section .note.GNU-stack,"",@progbits ``` # 2 解析 这里我们首先需要关注的是对于数组的初始化,我们是在函数内声明的,所以用的栈空间,可以看到main函数,在入栈是申请了40个字节空间 ```asm subq $40, %rsp ``` 而后把我们的5个元素分别放到了这个40个字节里 ```asm movl $1, (%rsp) movl $2, 4(%rsp) movl $3, 8(%rsp) movl $4, 12(%rsp) movl $5, 16(%rsp) ``` 最后将栈顶地址,也就是数组第一个元素的地址传给rdi,也就是第一个参数 ```asm movq %rsp, %rdi ``` 在sum中,对于数组元素的读取通过 ```asm addl (%rdi,%rdx,4), %eax ``` 每次偏移4个字节读取数据。
回帖
消灭零回复
提交回复
热议榜
java 相关知识分享
8
好的程序员与不好的程序员
6
写给工程师的十条精进原则
5
spring boot以jar包运行配置的logback日志文件没生成
5
一步一步分析SpringBoot启动源码(一)
5
MockMvc测试
5
【吐槽向】是不是有个吐槽的板块比较好玩
4
logstash jdbc同步mysql多表数据到elasticsearch
3
IntelliJ IDEA 优质License Server
3
.gitignore忽略规则
3
SpringBoot启动源码分析
3
一步一步分析SpringBoot启动源码(三)
3
2
一步一步分析SpringBoot启动源码(二)
2
积分不够将无法发表新帖
2
官方产品
Meta-Boot - 基于MCN
MCN - 快速构建SpringBoot应用
微信扫码关注公众号