明天面试?吓得我赶紧手写了一个Spring

明天面试?吓得我赶紧手写了一个Spring

引言

几乎每个面试的程序员都会碰到Spring相关的面试问题,或浅或深。你都是如何回答面试官的问题的?——我不知道,我一般会通过手写一个Spring来加深自己的印象。

目标

人见人爱的Spring已然不仅仅只是一个框架了。如今,Spring已然成为了一个生态。但深入了解Spring的却寥寥无几。这里,我带大家一起来看看,我是如何手写Spring的。我将结合对Spring十多年的研究经验,用不到400行代码来描述SpringIOC、DI、MVC的精华设计思想,并保证基本功能完整。

开始

首先,我们先来介绍一下Spring的三个阶段,配置阶段、初始化阶段和运行阶段(如图):

image

配置阶段:主要是完成application.xml配置和Annotation配置。

初始化阶段:主要是加载并解析配置信息,然后,初始化IOC容器,完成容器的DI操作,已经完成HandlerMapping的初始化。

运行阶段:主要是完成Spring容器启动以后,完成用户请求的内部调度,并返回响应结果。

先来看看我们的项目结构(如下图)

image

一、配置阶段

我采用的是maven管理项目。先来看pom.xml文件中的配置,我只引用了servlet-api的依赖。

明天面试?吓得我赶紧手写了一个Spring

然后,创建GPDispatcherServlet类并继承HttpServlet,重写init()、doGet()和doPost()方法。

明天面试?吓得我赶紧手写了一个Spring

在web.xml文件中配置以下信息:

明天面试?吓得我赶紧手写了一个Spring

在<init-param>中,我们配置了一个初始化加载的Spring主配置文件路径,在原生框架中,我们应该配置的是classpath:application.xml。在这里,我们为了简化操作,用properties文件代替xml文件。以下是properties文件中的内容:

明天面试?吓得我赶紧手写了一个Spring

接下来,我们要配置注解。现在,我们不使用Spring的一针一线,所有注解全部自己手写。

创建GPController注解:

明天面试?吓得我赶紧手写了一个Spring

创建GPRequestMapping注解:

明天面试?吓得我赶紧手写了一个Spring

创建GPService注解:

明天面试?吓得我赶紧手写了一个Spring

创建GPAutowired注解:

明天面试?吓得我赶紧手写了一个Spring

创建GPRequestParam注释:

明天面试?吓得我赶紧手写了一个Spring

使用自定义注解进行配置:

明天面试?吓得我赶紧手写了一个Spring

到此,我们把配置阶段的代码全部手写完成。

各位大佬,我有在公开课上有现场直播手写Spring,欢迎大家关注。可以加群:895244712,了解具体详情。还有JVM、dubbo、netty等其他知识分享,欢迎加入学习。

二、初始化阶段

先在GPDispatcherServlet中声明几个成员变量:

明天面试?吓得我赶紧手写了一个Spring

当Servlet容器启动时,会调用GPDispatcherServlet的init()方法,从init方法的参数中,我们可以拿到主配置文件的路径,从能够读取到配置文件中的信息。前面我们已经介绍了Spring的三个阶段,现在来完成初始化阶段的代码。在init()方法中,定义好执行步骤,如下:

明天面试?吓得我赶紧手写了一个Spring

doLoadConfig()方法的实现,将文件读取到Properties对象中:

明天面试?吓得我赶紧手写了一个Spring

doScanner()方法,递归扫描出所有的Class文件

明天面试?吓得我赶紧手写了一个Spring

doInstance()方法,初始化所有相关的类,并放入到IOC容器之中。IOC容器的key默认是类名首字母小写,如果是自己设置类名,则优先使用自定义的。因此,要先写一个针对类名首字母处理的工具方法。

明天面试?吓得我赶紧手写了一个Spring

然后,再处理相关的类。

明天面试?吓得我赶紧手写了一个Spring

doAutowired()方法,将初始化到IOC容器中的类,需要赋值的字段进行赋值

明天面试?吓得我赶紧手写了一个Spring

initHandlerMapping()方法,将GPRequestMapping中配置的信息和Method进行关联,并保存这些关系。

明天面试?吓得我赶紧手写了一个Spring

到此,初始化阶段的所有代码全部写完。

三、运行阶段

来到运行阶段,当用户发送请求被Servlet接受时,都会统一调用doPost方法,我先在doPost方法中再调用doDispach()方法,代码如下:

明天面试?吓得我赶紧手写了一个Spring

doDispatch()方法是这样写的:

明天面试?吓得我赶紧手写了一个Spring

收尾

到此,我们完成了一个mini版本的Spring,麻雀虽小,五脏俱全。我们把服务发布到web容器中,然后,在浏览器输入:http://localhost:8080/demo/query.json?name=Tom,就会得到下面的结果:

明天面试?吓得我赶紧手写了一个Spring

当然,真正的Spring要复杂很多,但核心设计思路基本如此。例如:Spring中真正的HandlerMapping是这样的:

明天面试?吓得我赶紧手写了一个Spring

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 举报,一经查实,本站将立刻删除。

发布者:全栈程序员-用户IM,转载请注明出处:https://javaforall.cn/101344.html原文链接:https://javaforall.cn

【正版授权,激活自己账号】: Jetbrains全家桶Ide使用,1年售后保障,每天仅需1毛

【官方授权 正版激活】: 官方授权 正版激活 支持Jetbrains家族下所有IDE 使用个人JB账号...

(0)
blank

相关推荐

  • 可浮动placeholder,让你的登录不再枯燥

    可浮动placeholder,让你的登录不再枯燥前言在登录twitter的时候发现他的输入框的placeholder是可以浮动的。当输入框获取到焦点的时候,placeholder会跑到上面去。我觉得这样的登录方式的好处是:可以减少一个label,同时往上浮动又可以保证用户在输入的时候知道输入什么内容。pointer-eventspointer-events属性设置HTML元素如何响应鼠标/触摸事件/单击/点击事件以及光标是否可见。虽然pointer-events属性有11个可能的值,但其中8个值都用于SVG。任何HTMl元素的三个

  • 什么是系统平均负载(Load average)

    什么是系统平均负载(Load average)一、什么是系统平均负载(Loadaverage)?在Linux系统中,uptime、w、top等命令都会有系统平均负载loadaverage的输出,那么什么是系统平均负载呢?LoadAver

  • js 数组删除和添加数据「建议收藏」

    js 数组删除和添加数据「建议收藏」}//新增checkbox选中监听事件table.on(‘checkbox(LAY-team-add)’,function(obj){alert(obj.checked)varid=obj.data.id;if(obj.checked){addCheckbox.push(id);alert(addCheckbox)…

  • 计算机主机后面板接口名称,i/o背板接口是计算机主机与什么连接的插座结合?…

    计算机主机后面板接口名称,i/o背板接口是计算机主机与什么连接的插座结合?…

    2021年11月27日
  • Awvs详细使用教程「建议收藏」

    Awvs详细使用教程「建议收藏」Awvs的是一款非常好用的web漏洞扫描工具,他的扫描速度比较快,可以自己选择扫描速度,比较灵活。Awvs分为老的版本和新版本,下面我介绍的是新版本的功能和用法。功能介绍如下:仪表盘(监视器)功能,添加目标功能,漏洞排序功能,扫描功能,发现功能,用户功能,扫描配置功能,网络扫描功能,追踪器功能,防火墙设置,邮件设置,引擎,时间排除功能,代理功能,常规设置主要使用的功能是前面的6个,后面的根据个人的需要进行配置详细介绍如下:Dashboard功能:翻译意思仪表盘(监视器),可以对扫描对扫描

    2022年10月22日
  • linux心跳出血漏洞,heartbleeder 自动检测 OpenSSL 心脏出血漏洞 (附修复指南)[通俗易懂]

    linux心跳出血漏洞,heartbleeder 自动检测 OpenSSL 心脏出血漏洞 (附修复指南)[通俗易懂]heartbleeder可以探测你的服务器是否存在OpenSSLCVE-2014-0160漏洞(心脏出血漏洞)。什么是心脏出血漏洞?CVE-2014-0160,心脏出血漏洞,是一个非常严重的OpenSSL漏洞。这个漏洞使得攻击者可以从存在漏洞的服务器上读取64KB大小的内存信息。这些信息中可能包含非常敏感的信息,包括用户请求、密码甚至证书的私钥。据称,已经有攻击者在某宝上尝试使用漏洞…

发表回复

您的电子邮箱地址不会被公开。

关注全栈程序员社区公众号