Spring框架XML与注解形式配置对比,有图有案例

简介: Spring框架XML与注解形式配置对比,有图有案例


一、 XML配置形式 VS 注解配置类形式


XML:

  1. 编写SpringConfig.xml文件


<?xml version="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 http://www.springframework.org/schema/beans/spring-beans.xsd">
   // 定义Bean信息
   <bean id="user" class="cn.liuliang.studysoundcodespring.entity.User">
       <property name="name" value="j3-liuliang"/>
       <property name="age" value="18"/>
   </bean>
</beans>


2.编写测试类


@Test
public void test02(){
    // 根据xml配置文件获取应用上下文
    ApplicationContext applicationContext = new ClassPathXmlApplicationContext("SpringConfig.xml");
    // 根据class获取相关bean
    User bean = applicationContext.getBean(User.class);
    System.out.println(bean);
}


3.结果:


image.png


注解


  1. 定义注解配置类


@Configuration //声明该类是配置类
@ComponentScan("cn.liuliang.studysoundcodespring") //包扫描
public class SpringConfig {
/**
  * 向容器中主入一个bean组件
  * @return
  */
 @Bean
 public User user(){
     // 通过new创建对象,放入容器中
     return new User("j3-liuliang",28);
 }
}


2.编写测试


@Test
public void test01(){
// 注解配置类应用上下文
ApplicationContext applicationContext = new AnnotationConfigApplicationContext(SpringConfig.class);
User user = applicationContext.getBean(User.class);
System.out.println(user);
}


3.结果:


image.png


注意: 通过@Bean的形式是使用的话, bean的默认名称是方法名,若@Bean(value=“bean的名称”) 那么bean的名称是指定的


1.1 优缺点比较

注解


优点

  1. 简化配置
  2. 使用起来简单,提升开发效率


缺点

  1. 无法配置第三方jar包中的类


XML


优点

  1. 类与类间的松藕合,容易扩展、更换
  2. 对象间的关系一目了然


缺点


  1. 配置冗长,且还要额外多维护一份配置
  2. 类型不安全,compile无法帮忙校验,运行期才会发现错误


上面的对比较为浅显,我自己认为这是不够的(本着对技术负责任的态度)但我本身技术能力有限总结不出较为全面的比较结果!


下面是我在CSDN上看到的一位博主对注解与XML配置的比较,对比很全面


image.png


注解与XML配置的区别


注解:是一种分散式的元数据,与源代码紧绑定。


xml:是一种集中式的元数据,与源代码无绑定。


因此注解和XML的选择上可以从两个角度来看:分散还是集中,源代码绑定/无绑定。


注解的缺点:


1、很多朋友比如在使用spring注解时,会发现注解分散到很多类中,不好管理和维护;这个其实要借助工具,我目前使用的是IDEA,它在这方面表现的非常好;当然现在还有Spring的STS,也是不错的; 所以借助工具,能解决这个问题;


2、注解的开启/关闭必须修改源代码,因为注解是源代码绑定的,如果要修改,需要改源码,这个有这个问题,所以如果是这种情况,还是使用XML配置方式;比如数据源;


3、注解还一个缺点就是灵活性,比如在之前翻译的Spring Framework 4.0 M1: WebSocket 支持;在实现复杂的逻辑上,没有XML来的更加强大;注解就是要么用,要么不用,比如之前的jpa bean validation,要么全,要么没;遇到这种情况很痛苦;


4、还一种就是约定大于配置,但是在处理一些复杂的情况下,注解还是需要的(如Spring的数据验证/数据绑定注解很强大);


5、通用配置还是走XML吧,比如事务配置,比如数据库连接池等等,即通用的配置集中化,而不是分散化,如很多人使用@Transactional来配置事务,在很多情况下这是一种太分散化的配置;


6、XML方式比注解的可扩展性和复杂性维护上好的多,比如需要哪些组件,不需要哪些;在面对这种情况,注解扫描机制比较逊色,因为规则很难去写或根本不可能写出来;


注解的好处:


1、XML配置起来有时候冗长,此时注解可能是更好的选择,如jpa的实体映射;注解在处理一些不变的元数据时有时候比XML方便的多,比如springmvc的数据绑定,如果用xml写的代码会多的多;


2、注解最大的好处就是简化了XML配置;其实大部分注解一定确定后很少会改变,所以在一些中小项目中使用注解反而提供了开发效率,所以没必要一头走到黑;


3、注解相对于XML的另一个好处是类型安全的,XML只能在运行期才能发现问题。


注解也好,XML也好,我们还是需要一些开关/替换机制来控制特殊需求,以改变那种要么全部 要么没有的方案。


还一种呼声就是约定大于配置,这种方案可能在某些场景下是最优的,但是遇到一些复杂的情况可能并不能解决问题,所以此时注解也是一个不错的方案。尤其在使用springmvc时,好处是能体会的出的。


不管使用注解还是XML,做的事情还是那些事情,但注解和XML都不是万能的,满足自己的需求且已一种更简单的方式解决掉问题即可。


就像探讨一下技术问题,很多人都带有很强的个人喜好来评判一个东西的好坏,这种探讨没有任何意义,我们最终的目的是解决方案,所以我们应该探讨的是能不能解决问题,能不能以更容易理解的方式解决问题,能不能更简单的解决问题。


不管是约定大于配置、注解还是XML配置也好,没有哪个是最优的,在合适的场景选择合适的解决方案这才是重要的。就像设计模式一样:是对特定环境中重复出现的特定问题的一个经过前人验证了的解决方案。


结束语


由于博主才疏学浅,难免会有纰漏,假如你发现了错误或偏见的地方,还望留言给我指出来,我会对其加以修正。如果你觉得文章还不错,你的转发、分享、点赞、留言就是对我最大的鼓励。感谢您的阅读,十分欢迎并感谢您的关注。


image.png

目录
相关文章
|
6天前
|
XML Java 程序员
Spring6框架中依赖注入的多种方式(推荐构造器注入)
依赖注入(DI)是一种过程,对象通过构造函数参数、工厂方法的参数或在对象实例构建后设置的属性来定义它们的依赖关系(即与其一起工作的其他对象)。
18 3
|
4天前
|
Java 程序员 Maven
|
4天前
|
JavaScript Java 测试技术
基于SpringBoot+Vue+uniapp的框架仓库系统的详细设计和实现(源码+lw+部署文档+讲解等)
基于SpringBoot+Vue+uniapp的框架仓库系统的详细设计和实现(源码+lw+部署文档+讲解等)
|
4天前
|
IDE Java Maven
Springboot中Processor注解概念以及实战案例
【5月更文挑战第28天】在Spring Boot中,没有直接名为Processor的注解。不过,你可能是在谈论与Spring Boot相关的注解处理器(Annotation Processors)的概念,尤其是在处理自定义注解或@ConfigurationProperties注解时的情况。
16 1
|
8天前
|
XML Java 测试技术
Spring框架
Spring框架
19 1
|
8天前
|
Java Spring 容器
Spring注解开发,bean的作用范围及生命周期、Spring注解开发依赖注入
Spring注解开发,bean的作用范围及生命周期、Spring注解开发依赖注入
21 1
Spring注解开发,bean的作用范围及生命周期、Spring注解开发依赖注入
|
8天前
|
JavaScript 前端开发
1天搞定SpringBoot+Vue全栈开发 (5)Vue框架快速上手
1天搞定SpringBoot+Vue全栈开发 (5)Vue框架快速上手
|
8天前
|
缓存 NoSQL Java
Spring Cache之本地缓存注解@Cacheable,@CachePut,@CacheEvict使用
SpringCache不支持灵活的缓存时间和集群,适合数据量小的单机服务或对一致性要求不高的场景。`@EnableCaching`启用缓存。`@Cacheable`用于缓存方法返回值,`value`指定缓存名称,`key`定义缓存键,可按SpEL编写,`unless`决定是否不缓存空值。当在类上使用时,类内所有方法都支持缓存。`@CachePut`每次执行方法后都会更新缓存,而`@CacheEvict`用于清除缓存,支持按键清除或全部清除。Spring Cache结合Redis可支持集群环境。
54 5
|
9天前
|
Java Spring 容器
Spring AOP 代码案例
Spring AOP 代码案例
20 1
|
17天前
|
XML Java 数据格式
Spring高手之路18——从XML配置角度理解Spring AOP
本文是全面解析面向切面编程的实践指南。通过深入讲解切面、连接点、通知等关键概念,以及通过XML配置实现Spring AOP的步骤。
28 6
Spring高手之路18——从XML配置角度理解Spring AOP