CSAPP L7 Machine-Level Programming III: Procedures

本文深入探讨了程序执行中的过程调用,包括栈结构、调用约定、参数传递和局部数据管理。讲解了如何通过栈来管理控制权传递,以及如何优化调用过程以减少开销。此外,还详细阐述了递归的概念,说明C编译器如何处理递归调用,无需额外考虑。重点讨论了寄存器在函数调用中的作用,以及如何通过调整栈帧来管理局部变量。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

这一节主要讲 Procedures,包含

  • Stack Structure
  • Calling Conventions
    • Passing control
    • Passing data
    • Managing local data
  • Illustration of Recursion

在这里插入图片描述
如何传入参数?
函数调用返回正确的位置?
减少调用过程的开销:原则 - 只做必要的事

内存的一部分 - 栈 :用来管理过程调用与返回的状态

Passing control

在这里插入图片描述
栈顶在下,push 栈指针递减, pop 栈指针递增。deallocate - 栈指针移动
在这里插入图片描述

无法显示操作 %rip

Passing data

在这里插入图片描述

前六个参数被存入到相对应的寄存器中,超出的参数将被放置到栈上的内存,寄存器访问比内存访问快得多

Managing local data

在这里插入图片描述
栈帧:用于特定 call 的每个内存块称为栈帧

在这里插入图片描述
默认分配16个字节,当无法提前得知分配空间大小时会使用 %rbp
在这里插入图片描述

在这里插入图片描述

改变了 p 指针,返回的是原来指针所指向的地址。 %rax 未动,改变的是 %rsi → %rdi
在这里插入图片描述
在这里插入图片描述

寄存器不会永远地存储某个值,在函数调用过程中新值会覆盖旧值,callee 约定会使得函数调用后把相应寄存器的值恢复到调用以前寄存器中存储的值。
在这里插入图片描述
在这里插入图片描述

Illustration of Recursion

C 编译器无需额外考虑递归情况

在这里插入图片描述
总结:
在这里插入图片描述

### Spring Boot 整合 MyBatis不到数据库的原因分析 在 Spring Boot 中整合 MyBatis 并配置数据库连接时,如果遇到无法到数据库的情况,可能是由于以下几个原因引起的: #### 1. **数据源配置错误** 如果 `application.properties` 或 `application.yml` 文件中的数据源配置项填写错误,则可能导致程序无法正确连接到目标数据库。常见的错误包括但不限于: - 数据库 URL 错误(例如拼写错误或端口号不对)[^2]。 - 用户名或密码错误。 正确的数据源配置应类似于以下形式: ```properties spring.datasource.url=jdbc:mysql://localhost:3306/your_database_name?useUnicode=true&characterEncoding=utf8&serverTimezone=UTC spring.datasource.username=root spring.datasource.password=password spring.datasource.driver-class-name=com.mysql.cj.jdbc.Driver ``` #### 2. **依赖版本冲突** 如果项目中引入的 MyBatisSpring Boot 的版本不兼容,可能会导致初始化失败或者无法正常加载数据库资源。建议检查项目的 `pom.xml` 文件,确保使用的依赖版本匹配。例如: ```xml <dependency> <groupId>org.mybatis.spring.boot</groupId> <artifactId>mybatis-spring-boot-starter</artifactId> <version>2.3.0</version> </dependency> ``` #### 3. **未启用 Mapper 接口扫描** 如果没有正确配置 `@MapperScan` 注解来指定 Mapper 接口所在的包路径,MyBatis 将无法识别这些接口,从而引发异常。可以通过以下方式解决此问题[^3]: ```java @SpringBootApplication @MapperScan("com.example.mapper") // 替换为实际的 mapper 路径 public class Application { public static void main(String[] args) { SpringApplication.run(Application.class, args); } } ``` #### 4. **数据库服务不可用** 当本地开发环境下的 MySQL 或其他数据库服务未启动时,也会报出类似的 “不到数据库” 错误。可以尝试通过命令行或其他工具手动测试数据库连通性,确认其状态是否正常运行。 #### 5. **IDEA 缺乏 SQL 提示支持** 若开发者希望获得更友好的编码体验,在 IDEA 上完成相应设置后能够享受智能补全功能带来的便利。具体做法可参照文档说明调整插件选项以便增强用户体验效果[^4]。 --- ### 解决方案总结 针对上述可能存在的各类状况逐一排查即可定位根本所在;同时注意保持各组件间良好的协作关系以减少不必要的麻烦发生几率。 ```java // 示例代码片段展示如何定义一个简单的 DAO 层类 public interface UserMapper extends BaseMapper<UserEntity> {} ```
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值