Spring4.x基础配置(一):依赖注入

809 阅读3分钟
原文链接: blog.longjiazuo.com

Spring框架本身的四大原则:

(1) 使用POJO进行轻量级和最小侵入式开发。
(2) 通过依赖注入和基于接口编程实现松耦合。
(3) 通过AOP和默认习惯进行声明式编程。
(4) 使用AOP和模板(template)减少模式化代码。
Spring所有功能的设计和实现都是基于此四大原则的。

一. 依赖注入

1. 点睛

我们经常说的控制反转(Inversion of Control-IOC)和依赖注入(dependency injection-DI)在Spring环境下是等同的概念,控制反转是通过依赖注入来实现的。所谓依赖注入是指的是容器负责创建对象和维护对象间的依赖关系,而不是通过对象本身负责自己的创建和解决自己的依赖。
依赖注入的主要目的是为了解耦,体现了一种”组合”的理念。如果你希望你的类具备某项功能的时候,是继承自一个具有此功能的父类好呢?还是组合另外一个具有这个功能的类好呢?答案是不言而喻的,继承一个父类,子类将会与父类耦合,组合另外一个类则使耦合度大大降低。
Spring IoC容器(ApplicationContext)负责创建Bean,并通过容器将功能类Bean注入到你需要的Bean中。Spring提供使用xml,注解,Java配置,groovy配置实现Bean的创建和注入。
无论是xml配置,注解配置还是Java配置,都被称为配置元数据,所谓元数据即描述数据的数据。元数据本身不具备任何可执行的能力,只能通过外界代码来对这些元数据行解析后进行一些有意义的操作。Spring容器解析这些配置元数据进行Bean初始化,配置和管理依赖。
声明Bean的注解:

@Component 组件,没有明确的角色。
@Service 在业务逻辑层(service层)使用。
@Repository 在数据访问层(dao层)使用。
@Controller在展现层(MVC——>SpringMVC)使用。

注入Bean的注解,一般情况下通用。

@Autowired:Spring提供的注解。
@Inject:JSR-330提供的注解。
@Resource:JSR-250提供的注解。

@Autowired@Inject@Resource可注解在set方法或者属性上,我个人的习惯是注解在属性上。

二.示例

1. 编写功能类的Bean

package org.light4j.sping4.base.di;

import org.springframework.stereotype.Service;

@Service //①
public class FunctionService {
    public String sayHello(String word){
        return "Hello " + word +" !"; 
    }

}

代码解释:

①使用@Service注解声明当前FunctionService类是Spring容器管理的一个Bean。其中,使用@Component,@Service,@Repository@Controller是等效的,可以根据自己的需要选用。

2. 使用功能类的Bean

package org.light4j.sping4.base.di;

import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.stereotype.Service;

@Service //①
public class UseFunctionService {
    @Autowired //②
    FunctionService functionService;

    public String SayHello(String word){
        return functionService.sayHello(word);
    }

}

代码解释:

①使用@Service注解声明当前UseFunctionService 类是Spring容器管理的一个Bean
②使用@AutowiredFunctionService的实体Bean注入到UseFunctionService 中,让UseFunctionService具备FunctionService的功能,此处使用JSR-330@Inject注解或者JSR-250的@Resource注解是等效的。

3. 配置类

package org.light4j.sping4.base.di;

import org.springframework.context.annotation.ComponentScan;
import org.springframework.context.annotation.Configuration;

@Configuration //①
@ComponentScan("org.light4j.sping4.base.di") //②
public class DiConfig {

}

代码解释:

@Configuration声明当前类是一个配置类。
②使用@ComponentScan注解将会自动扫描包名下所有使用@Service,@Component,@Repository@Controller的类,并注册为Bean。

4. 运行

package org.light4j.sping4.base.di;

import org.springframework.context.annotation.AnnotationConfigApplicationContext;

public class Main {
    public static void main(String[] args) {
         AnnotationConfigApplicationContext context = new AnnotationConfigApplicationContext(DiConfig.class); //①

         UseFunctionService useFunctionService = context.getBean(UseFunctionService.class); //②

         System.out.println(useFunctionService.SayHello("world"));

         context.close();
    }
}

代码解释:

①使用AnnotationConfigApplicationContext作为Spring容器,接受输入一个配置类作为参数。
②获得声明配置的UseFunctionServiceBean

运行结果如下所示:
di

5. 源代码示例:

github地址:点击查看
码云地址:点击查看

打赏 欢迎关注人生设计师的微信公众账号
公众号ID:longjiazuoA