前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
工具
TVP
发布
社区首页 >专栏 >Spring框架IoC控制反转

Spring框架IoC控制反转

原创
作者头像
久绊A
发布2024-03-01 13:34:49
810
发布2024-03-01 13:34:49
举报
文章被收录于专栏:IT-Learning-NotesIT-Learning-Notes

一、Spring框架是什么

Spring是与2003年兴起的一个轻量级的Java开发框架,它是为了解决企业应用开发的复杂性而创建的。Spring的核心是控制反转(IOC)和面向切面编程(AOP)。Spring是可以在Java SE/EE中使用的轻量级开源框架。

Spring的主要作用就是为代码"解耦",降低代码间的耦合度。就是让对象和对象(模板和模板)之间关系不是使用代码关联,而是通过配置来说明。即在Spring中说明对象(模块)的关系。

Spring根据代码的功能特点,使用IOC降低业务对象之间耦合度。IOC使得主业务在相互调用过程中,不用再自己维护关系了,即不用再自己创建要使用的对象了,而是由Spring容器统一管理,自动"注入",注入即赋值。而AOP使得系统服务得到了最大复用,且不用再由及程序手工将系统及服务"混杂"到主业务逻辑中了,而是由Spring容器统一完成。

二、IoC控制反转

IoC(Inversion of Control)控制反转,指导开发人员如何使用对象,管理对象的。把对象的创建,属性赋值,对象的生命周期都交给代码之外的容器管理,IoC的用处在于减少组件之间的耦合,增加代码的可扩展性和可维护性。它通过外部容器来管理对象的创建和依赖注入,使得系统更灵活、可配置,并能够适应需求的变化。

三、添加依赖

代码语言:javascript
复制
      	<dependency>
            <groupId>org.mybatis</groupId>
            <artifactId>mybatis</artifactId>
            <version>3.5.13</version>
        </dependency>
        
        <dependency>
            <groupId>org.junit.jupiter</groupId>
            <artifactId>junit-jupiter-api</artifactId>
            <version>5.7.2</version>
            <scope>test</scope>
        </dependency>
        
        <dependency>
            <groupId>org.junit.jupiter</groupId>
            <artifactId>junit-jupiter-engine</artifactId>
            <version>5.7.2</version>
            <scope>test</scope>
        </dependency>
        
        <dependency>
            <groupId>mysql</groupId>
            <artifactId>mysql-connector-java</artifactId>
            <version>8.0.23</version>
        </dependency>

Spring Context

是一个XML注释,用于在Maven或Gradle构建工具的配置文件中提供对Spring Framework中的Spring Context模块的依赖声明。

Spring Context模块是Spring Framework的核心模块之一,提供了IoC容器和依赖注入的支持。它是实现控制反转(IoC)和依赖注入(DI)的基础。

代码语言:javascript
复制
<dependency>
    <groupId>org.springframework</groupId>
    <artifactId>spring-context</artifactId>
    <version>5.3.9</version>
</dependency>

四、创建配置文件

在项目的资源文件夹(例如src/main/resources)下创建一个名为beans.xml的配置文件,内容如下:

代码语言:javascript
复制
<?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 id="someService" class="com.example.SomeServiceImpl" />
</beans>

这个元素用于声明一个bean。在这个例子中,id属性指定了bean的唯一标识符为"someService",class属性指定了bean的实现类为com.example.SomeServiceImpl

这个配置文件告诉Spring容器创建一个名为"someService"的bean,并使com.example.SomeServiceImpl类来实例化它。创建的bean将被放置在Spring的容器中,可以通过在应用程序中引用其ID来访问和使用。

五、创建实现类

代码语言:javascript
复制
public class SomeServiceImpl implements SomeService {
    @Override
    public void doSome() {
        System.out.println("hello world");
    }
}

六、创建接口

代码语言:javascript
复制
public interface SomeService {
    void doSome();
}

七、编写测试类

代码语言:javascript
复制
import com.example.port.SomeService;
import org.junit.jupiter.api.Test;
import org.springframework.context.ApplicationContext;
import org.springframework.context.support.ClassPathXmlApplicationContext;

public class MyTest {

    @Test
    public void testdoSomething() {
        //SomeService service = new SomeServiceImpl();
        //service.doSome();

        //1.指定spring配置文件:从类路径(classpath)之下开始的路径
        String config="beans.xml";

        //2.创建容器对象 ApplicationContext 表示spring容器对象。通过ctx获取某个java对象
        ApplicationContext ctx = new ClassPathXmlApplicationContext(config);

        //3.从容器中获取指定名称的对象,使用getBean("id")
        SomeService service = (SomeService)ctx.getBean("someService");

        //4.调用对象的方法
        service.doSome();
    }
}

原创声明:本文系作者授权腾讯云开发者社区发表,未经许可,不得转载。

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

原创声明:本文系作者授权腾讯云开发者社区发表,未经许可,不得转载。

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

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