Spring源码学习之IDEA搭建Spring源码Debug环境

开发 前端
学习开源框架的源码时,搭建一个可以方便地进行调试的环境是非常重要的,不明白的地方也可以修改一下源码的东西!看了好多文章,都是比较老的,现在跟着搭建是有问题的,踩了很多坑,最终完成搭建,整理一下思路还是比较清晰的,让我们一起来试试吧!

一、前言

大家肯定都debug过spring的源码,看看bean的创建过程,有个缺点不能自己随意的添加注释。

学习开源框架的源码时,搭建一个可以方便地进行调试的环境是非常重要的,不明白的地方也可以修改一下源码的东西!

看了好多文章,都是比较老的,现在跟着搭建是有问题的,踩了很多坑,最终完成搭建,整理一下思路还是比较清晰的,让我们一起来试试吧!

二、下载导入Idea

本次小编使用的Idea版本为2021.3,不太建议使用低版本的。

1、下载源码

可以通过github或者gitee进行下载,也可以直接clone,文件比较大,这里建议直接下载好在Idea中打开即可!

由于Spring6需要JDK17,短时间也不会使用到,我们还是以Spring5的源码来学习哈,本地下载的Spring版本为:5.3.X

Spring5.3.X下载地址:https://github.com/spring-projects/spring-framework/tree/5.3.x

解压完成:

2、导入Idea

因为Spring官方已经把Gradle作为构建依赖的工具了,网上有好多都要下载Gradle进行配置的,其实Idea是会帮我们下载并应用的,我们只需要把源码导入静静的等待Idea表演即可!

这时我们把项目导入到Idea中:

这里我们选中Gradle。

点击相信项目:

小编不是第一次加载,所以很快,第一次的时候已经下载过Gradle了,专门导入一个新的让大家看一下:

稍等三五分组就构建成功了!

我们来说一下怎么知道下载那个版本的Gradle呢?

「Spring5.3.X是需要gradle-7.5.1-bin.zip」

如果想下载Gradle源码的可以去下载你想要的版本,这种带all的才是有源码的哈!

Gradle下载地址:https://services.gradle.org/distributions/

三、项目完善

现在已经构建完成了,我们现在需要新建一个模块,去使用我们刚刚构建的spring源码即可!

1、新建Module

我们新建一个Gradle模块:

指定父模块和名称:

我们可以查看一下目录下的settings.gradle文件是否新增成功,我们看到include 'myspring',说明我们已经新增模块成功!

2、新模块导入依赖

这里是个大坑,坑了我一天,所有的教程都是使用compile来导入依赖的,但是之前使用的Gradle版本都是7.0之前的,之前肯定没有问题,现在我们使用的是7.5.1。compile命令是被弃用的,不要问我咋知道的,我问的chatGPT,知道他不靠谱但是没有办法只能试一下,果然好用!!

「compile关键字用于导入依赖项的语法在Gradle 7.0及更早版本中是有效的。但是,从Gradle 7.0开始,官方推荐使用implementation代替compile」。

「自从Gradle 7.0起,compile被弃用,并建议使用implementation、api、compileOnly等配置选项代替,以提供更清晰的依赖管理和构建性能优化。」。

我们添加一些主要的依赖,为了少些getset方法,我们在添加一下Lombok!

implementation(project(":spring-context"))
implementation(project(":spring-beans"))
implementation(project(":spring-core"))
implementation(project(":spring-aop"))
compileOnly 'org.projectlombok:lombok:1.18.20'
annotationProcessor 'org.projectlombok:lombok:1.18.20'

记得刷新依赖!

3、spring.xml文件配置

<?xml versinotallow="1.0" encoding="UTF-8"?>
<beans xmlns="http://www.springframework.org/schema/beans"
       xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
       xsi:schemaLocation="http://www.springframework.org/schema/beans
        https://www.springframework.org/schema/beans/spring-beans.xsd">

    <bean id="test" class="com.test.bean.Test">
  <property name="id" value="100"></property>
  <property name="name" value="Tom"></property>
    </bean>
</beans>

4、测试Bean

public class Test {

 private Long id;

 private String name;

 public Long getId() {
  return id;
 }

 public void setId(Long id) {
  this.id = id;
 }

 public String getName() {
  return name;
 }

 public void setName(String name) {
  this.name = name;
 }

 @Override
 public String toString() {
  return "Test{" +
    "id=" + id +
    ", name='" + name + '\'' +
    '}';
 }
}

5、测试类

public class SpringMain {

 public static void main(String[] args) {
  ApplicationContext context = new ClassPathXmlApplicationContext("spring.xml");
  Test test = context.getBean("test", Test.class);
  System.out.println(test);
 }
}

我们看到正常输出Bean!

如果使用中文就会乱码,我们改一下字符集还是不行,加上Gradle字符集还是不行!有知道的大佬欢迎分享一下哈~~

打了断点,spring内部是正确显示的:

获取到的也是正确的,就是输出的时候乱码!

这个对我们调试源码没有什么影响的!

6、源码跟进

我们按住Ctrl进入源码:

我们可以看到已经是我们自己下载的源码了,这样就可以本地debug学习了哈!

大家可以好好学习源码了哈!

我们看到在控制台输入一些报错信息,其实就是git的 问题:

zip 发行版旨在共享我们的源代码,但不一定用于构建它。构建的这一部分依赖于构建管道中存在的 git 文件。

解决方案就是clone项目,不要使用下载的方式,不过这个对我们调试代码没有任何影响哈!

Github官方回复地址:

org.gradle.process.internal.ExecException: Process 'command 'git'' finished with non-zero exit value 128
 at org.gradle.process.internal.DefaultExecHandle$ExecResultImpl.assertNormalExitValue(DefaultExecHandle.java:415)
 at org.gradle.process.internal.DefaultExecAction.execute(DefaultExecAction.java:38)
 at org.gradle.process.internal.DefaultExecActionFactory.exec(DefaultExecActionFactory.java:202)
 at io.spring.ge.conventions.gradle.WorkingDirectoryProcessOperations.exec(WorkingDirectoryProcessOperations.java:45)
 at io.spring.ge.conventions.gradle.ProcessOperationsProcessRunner.run(ProcessOperationsProcessRunner.java:40)
 at io.spring.ge.conventions.gradle.BuildScanConventions.run(BuildScanConventions.java:195)
 at io.spring.ge.conventions.gradle.BuildScanConventions.addGitMetadata(BuildScanConventions.java:139)
 at com.gradle.enterprise.gradleplugin.internal.extension.a$4.run(SourceFile:172)
 at java.util.concurrent.Executors$RunnableAdapter.call(Executors.java:511)
 at java.util.concurrent.FutureTask.run(FutureTask.java:266)
 at java.util.concurrent.ThreadPoolExecutor.runWorker(ThreadPoolExecutor.java:1142)
 at java.util.concurrent.ThreadPoolExecutor$Worker.run(ThreadPoolExecutor.java:617)
 at java.lang.Thread.run(Thread.java:745)

四、总结

通过搭建Spring源码Debug环境,我们能够更深入地了解Spring框架的运行机制,并通过实际调试经验加深对其内部工作原理的理解。这种深入学习可以帮助我们更好地应用和开发Spring框架,同时也提升了我们解决问题的能力。

我们看这种实时性的博客教程还是要看最新的,要不可能会有一些不适合新版的!

希望这篇博客对你有所帮助,祝你在学习Spring源码过程中取得成功!

责任编辑:姜华 来源: 小王博客基地
相关推荐

2022-12-07 08:02:43

Spring流程IOC

2021-07-09 07:52:34

SpringContextEventListen

2019-09-09 06:30:06

Springboot程序员开发

2022-12-05 08:41:39

Redis调试环境源码

2023-01-10 07:52:15

2020-10-14 06:23:54

SpringBean实例化

2012-02-14 14:05:59

JavaSpring

2024-11-13 19:03:14

2017-12-22 10:51:04

Hadoop编译环境

2021-04-28 06:26:11

Spring Secu功能实现源码分析

2021-06-07 14:06:19

Spring SecuCSRF防御

2017-06-07 14:58:39

Redis源码学习Redis事务

2022-02-07 15:02:42

SpringIDEA版本

2024-10-14 13:30:20

2015-03-31 18:26:43

陌陌社交

2016-09-20 10:26:25

LaravelPHPMiddleware

2015-10-08 14:03:01

TCP网络协议

2016-09-20 10:15:49

LaravelPHPContainer

2011-08-23 13:56:12

MySQLConnection

2021-01-25 16:28:10

鸿蒙HarmonyOS搭建环境
点赞
收藏

51CTO技术栈公众号