前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
工具
TVP
发布
社区首页 >专栏 >springboot核心原理

springboot核心原理

作者头像
三哥
发布2019-10-24 11:15:20
4800
发布2019-10-24 11:15:20
举报
文章被收录于专栏:java工会java工会

1.基于你对springboot的理解描述一下什么是springboot

它是一个服务于spring框架的框架,能够简化配置文件,快速构建web应用, 内置tomcat,无需打包部署,直接运行。

2.约定优于配置指的是什么?

maven 的目录结构 a) 默认有 resources 文件夹存放配置文件 b) 默认打包方式为 jar spring-boot-starter-web 中默认包含 spring mvc 相关依赖以及内置的 tomcat 容器,使得构建一个 web 应用更加简单 默认提供 application.properties/yml 文件 默认通过 spring.profiles.active 属性来决定运行环境时读取的配置文件 EnableAutoConfiguration 默认对于依赖的 starter 进行自动

3.@SpringBootApplication由哪几个注解组成,这几个注解分别表示什么作用

SpringBootApplication 本质上是由 3 个注解组成,分别是

@Configuration @EnableAutoConfiguration @ComponentScan @Configuration: 在启动类里面标注了@Configuration,意味着它其实也是一个 IoC 容器的配置类

@EnableAutoConfiguration: springboot 应用把所有符合条件的@Configuration 配置 都加载到当前 SpringBoot 创建并使用的 IoC 容器中。

@ComponentScan: ComponentScan 默认会扫描当前 package 下的的所有加 了@Component 、@Repository、@Service、@Controller的类到 IoC 容器中;

4.springboot自动装配的实现原理

(1)SpringApplication.run(AppConfig.class,args);执行流程中有refreshContext(context);这句话. (2)refreshContext(context);内部会解析我们的配置类上的标签.实现自动装配功能的注解@EnableAutoConfiguration (3)会解析@EnableAutoConfiguration这个注解里面的@Import引入的配置类.AutoConfigurationImportSelector (4)AutoConfigurationImportSelector这个类中有这个方法.SpringFactoriesLoader.loadFactoryNames(getSpringFactoriesLoaderFactoryClass(), getBeanClassLoader()); (5)SpringFactoriesLoader.loadFactoryNames的作用就是读取jar包中的/项目中的META-INF/spring.factories文件. (6)spring.factories配置了要自动装配的Configuration类

5.spring中的spi机制的原理是什么?

SPI的全名为Service Provider Interface,为某个接口寻找服务实现的机制。 当服务的提供者,提供了服务接口的一种实现之后,在jar包的META-INF/services/目录里同时创建一个以服务接口命名的文件。该文件里就是实现该服务接口的具体实现类。而当外部程序装配这个模块的时候,就能通过该jar包META-INF/services/里的配置文件找到具体的实现类名,并装载实例化,完成模块的注入。通过这个约定,就不需要把服务放在代码中了,通过模块被装配的时候就可以发现服务类了。

本文参与 腾讯云自媒体分享计划,分享自微信公众号。
原始发表:2019-10-19,如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 java工会 微信公众号,前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体分享计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
相关产品与服务
容器服务
腾讯云容器服务(Tencent Kubernetes Engine, TKE)基于原生 kubernetes 提供以容器为核心的、高度可扩展的高性能容器管理服务,覆盖 Serverless、边缘计算、分布式云等多种业务部署场景,业内首创单个集群兼容多种计算节点的容器资源管理模式。同时产品作为云原生 Finops 领先布道者,主导开源项目Crane,全面助力客户实现资源优化、成本控制。
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档