1200字范文,内容丰富有趣,写作的好帮手!
1200字范文 > SpringBoot的幕后推手 java互联网架构师系统vip课程

SpringBoot的幕后推手 java互联网架构师系统vip课程

时间:2020-04-19 12:49:12

相关推荐

SpringBoot的幕后推手 java互联网架构师系统vip课程

那么IoC容器分析和组装的依据是啥呢?Spring框架其实最早的时候只能通过XML配置文件来描述bean和bean之间的关系,但是随着Java生态研发技术以及理念的转变,又出现了基于Java代码和Annotation元信息的描述方式(比如@AutoWired和@Inject)。但是呢,无论使用哪一种配置方式,目的都是为了简化绑定逻辑描述的各种表象,最终也都是为本阶段的最终目的来服务。

四、JavaConfig是个什么鬼?

​Java 5的出世,加上当时基于纯Java Annatation的依赖注入框架Guice的出现,就使得Spring框架和社区不得不顺应民意,出版并持续完善了基于Java代码和Annotation元信息的依赖关系绑定描述方式,就是JavaConfig项目。

基于JavaConfig方式的依赖关系描述基本映射了早期基于XML方式的配置,比如:

1. 表达形式

XML配置方式如下:

<?xml version="1.0" encoding="UTF-8"?>

<beans xmlns:xsi=“/2001/XMLSchema-instance”

xmlns=“/schema/beans”

xmlns:context=“/schema/context”

xsi:schemaLocation="/schema/beans

/schema/beans/spring-beans-4.0.xsd

/schema/context

/schema/context/spring-context.xsd">

// bean定义

JavaConfig的配置方式如下:

@Configuration

public class DemoConfiguration {

// bean定义

}

也就是说任何一个被标注了@Configuration注解的Java类都是一个JavaConfig配置类。

2. 注册bean定义

XML配置方式:

JavaConfig配置方式:

@Configuration

public class DemoConfiguration {

@Bean

public DemoService demoService() {

return new DemoServiceImpl();

}

}

也就是说任何一个标注了@Bean注解的方法,它的返回值就将作为一个bean定义注册到Spring的IoC容器,方法名将默认成为该bean在容器中的id.

3. 表达依赖注入关系

XML配置形式:

JavaConfig形式:

@Configuration

public class DemoConfiguration {

@Bean

public AService aService() {

return new AServiceImpl();

}

@Bean

public BService bService() {

return new BServiceImpl(aService());

}

}

也就是说如果一个bean定义了依赖其他bean,就直接调用其对应JavaConfig类中依赖bean的创建方法即可。

从以上种种表象我们可以看出,以前Spring IoC容器中具有的特性在JavaConfig中都可以进行表述,只是换了另外的一种形式而已。并且通过声明相应的Java Annotation反而“内聚”一起了,变得更加简洁了。

五、那些常用的Annotation

@ComponentScan

​该注解对应的是XML配置中的<context:component-scan>元素,用于配合一些元信息Java Annotation,比如@Component@Repository等,将标注了这些注解的bean定义类批量采集到Spring的IoC容器中。

​我们可以通过basePackage等属性来细粒度的定制该注解自动扫描的范围,如果没有指定的话,则默认Spring框架会从声明@ComponentScan注解所在的类的package进行扫描

​这里还要说的@ComponentScan是SpringBoot框架得以实现的一个重要组件,我们以后还能在碰到它,也会做深入讲解。

**2. **@PropertySource@PropertySources

​注解@PropertySource用来从指定的地方来加载.properties配置文件,并且将其中的属性加载到IoC容器中,以便我们能用来填充一些bean定义的属性占位符(placeholder),当然它的实现需要PropertySourcesPlaceHolderConfigurer的配合。

若我们使用Java8或者更高的版本,那么我们可以并行声明多个@PropertySource,如:

@Configuration

@PropertySource(“classpath:1.properties”)

@PropertySource(“classpath:2.properties”)

@PropertySource("…")

public class XConfiguration {

}

若我们使用低于Java8版本的JDK进行开发Spring应用,我们就必须借助@PropertySources注解来实现声明多个@PropertySource了,如下:

@Configuration

@PropertySources({

@PropertySource(“classpath:1.properties”),

@PropertySource(“classpath:2.properties”),

})

public class XConfiguration {

}

3.@Import@ImportSource

在以前XML配置方式中,我们可以通过<import resource="xxx.xml"/>来将多个分开的容器配置合并到一个配置中,在JavaConfig形式的配置中,我们可以使用@Import这个注解完成同样的目的:

@Configuration

@Import(DemoConfiguration.class)

public class XConfiguration {

}

《一线大厂Java面试题解析+后端开发学习笔记+最新架构讲解视频+实战项目源码讲义》

【/doc/DSmxTbFJ1cmN1R2dB】 完整内容开源分享

注解@Import只能将以JavaConfig形式定义的配置引入到IoC容器,而若我们有一些以前遗留的配置或者遗留的系统需要以XML形式来配置(如Dubbo框架),我们就需要使用@ImportSource注解来将它们一起合并到以JavaConfig配置形式配置的容器中:

本内容不代表本网观点和政治立场,如有侵犯你的权益请联系我们处理。
网友评论
网友评论仅供其表达个人看法,并不表明网站立场。