Spring IOC入门

一、为啥需要IOC?

先举个咱们写作业常遇到的例子:做一个用户查询功能,得有UserService(业务层)和UserDAO(数据访问层),UserService要用到UserDAO。传统写法是这样的:

java 复制代码
// 传统写法
public class UserDAO {
    public void queryUser() { /* 查数据库 */ }
}

public class UserService {
    // 直接new一个UserDAO
    private UserDAO userDAO = new UserDAO();
    
    public void getUserInfo() {
        userDAO.queryUser();
    }
}

这种写法看着简单,但问题超明显------耦合度太高!如果后面要换数据库,得把UserDAO改成UserDAOImpl,这时候必须改UserService里的代码,特别麻烦。而且对象创建、依赖关系都要自己管,系统一复杂就乱套了,测试起来也不方便。

而IOC的作用就是解决这个问题:把创建对象、管理依赖的活儿从我们写的代码里抽出来,交给Spring容器来管,咱们只管写业务逻辑。

二、核心概念:IOC和DI到底是啥?

  1. IOC(控制反转):核心是"控制权转移"。以前是我们用new手动创建对象,现在把这个控制权交给Spring容器,这就是"反转"。

  2. DI(依赖注入):是实现IOC的具体方式。容器创建对象时,会自动把这个对象需要的依赖(比如UserService需要的UserDAO)塞进去,不用我们手动赋值。

总结:IOC是思想,DI是实现手段,核心都是让代码解耦、好维护。

三、Spring IOC怎么用?两种常用配置方式

1. 传统XML配置

早期Spring用XML配置Bean,需要写一个applicationContext.xml文件,把要管理的对象和依赖都配置进去:

java 复制代码
<!-- applicationContext.xml -->
<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="userDAO" class="com.example.UserDAO"/>
    <bean id="userService" class="com.example.UserService">
        <property name="userDAO" ref="userDAO"/&gt; <!-- 注入依赖 -->
    </bean>
</beans>

然后从容器里拿对象用,不用自己new了:

java 复制代码
// 初始化容器,获取对象
ApplicationContext context = new ClassPathXmlApplicationContext("applicationContext.xml");
UserService userService = context.getBean("userService", UserService.class);
userService.getUserInfo();

2. 主流注解配置(重点掌握)

现在都用注解配置,比XML简单太多!常用注解就几个,记熟就行:

  • @Component/@Service/@Repository/@Controller:标记类为Spring管理的Bean(后三个是分层专用,语义更清晰);

  • @Autowired:自动注入依赖;

  • @Configuration + @ComponentScan:替代XML文件,开启组件扫描。

java 复制代码
// DAO层:用@Repository标记
@Repository
public class UserDAO {
    public void queryUser() { System.out.println("查询用户"); }
}

// Service层:用@Service标记,@Autowired自动注入
@Service
public class UserService {
    @Autowired
    private UserDAO userDAO;
    
    public void getUserInfo() {
        userDAO.queryUser();
    }
}

// 配置类:替代XML
@Configuration
@ComponentScan(basePackages = "com.example") // 扫描指定包下的注解
public class SpringConfig {}

// 调用方式
public class Main {
    public static void main(String[] args) {
        ApplicationContext context = new AnnotationConfigApplicationContext(SpringConfig.class);
        UserService userService = context.getBean(UserService.class);
        userService.getUserInfo();
    }
}
相关推荐
青石路2 小时前
记一次多JDK版本问题的排查,一坑套一坑,差点没爬上来
java
像我这样帅的人丶你还5 小时前
Java 后端详解(五):Redis 缓存
java·后端·全栈
plainGeekDev7 小时前
GreenDAO → Room
android·java·kotlin
jiayou648 小时前
KingbaseES 表级与列级加密完全指南
数据库·后端
亦暖筑序12 小时前
Java 8老系统AI Workflow实战:把一次性AI对话升级成可恢复工作流
java·后端
敲代码的彭于晏13 小时前
Bean 生命周期完全图解:前端同学也能看懂的 Spring 核心机制
java·前端·后端
plainGeekDev14 小时前
ButterKnife → ViewBinding
android·java·kotlin
GBASE1 天前
G术时刻 |GBase 8s数据库事务并发控制之封锁技术介绍(下)
数据库
像我这样帅的人丶你还1 天前
Java 后端详解(四):分页与搜索
java·javascript·后端
她的男孩1 天前
数据权限为什么不能只靠注解?Forge 的 Mapper 层 SQL 改写源码拆解
java·后端·架构