1.IoC的目的在于让服务端的代码不需要改动
这段代码的问题在于,如果想要调用不同的dao层,就需要在服务端的代码Service层中进行改动
比如要调用dao1,Service层代码就是Dao dao1=new Dao1()
比如要调用dao2,Service层代码就是Dao dao2=new Dao2()
服务端的代码应该尽量不改动,客户端的代码可以随意改动
改进:这样服务端(Service层)的代码不用改动,你客户端传进来Dao1类的对象,那就调用Dao1,那就调用Dao1类的方法。如果客户端传进来Dao2类的对象,那就调用Dao2类的方法
之前,服务端来主动创建对象,控制权在服务端,服务端的代码是需要改变的
现在,服务端被动的接收对象,控制权在用户手上,服务端的代码是写死的,不需要改变
2.通过xml文件的方式实现IoC
这是一个Hello类
在xml 文件中进行配置:
id=''hello" id是这个bean标签在xml文件中的唯一标识符
class=“XXXXX” 表示这个类的路径,这个类的位置
name=“str‘ 表示给Hello这个类的str这个属性进行赋值
value=”Spring“ 表示给str这个属性赋值Spring(注意这里如果是ref=”XXX“,表示给这个属性赋值一个对象,这个对象已经在Spring容器里面创建好了)
最后就可以不用new的方式就创建出一个Hello类的对象
这样服务端代码就彻底不需要改了,只需要去xml文件中进行修改就行
3.依赖注入的三种方式
1.构造函数注入 在UserController这个类中注入了userService这个对象属性
public class UserController {
private UserService userService;
public UserController(UserService userService) {
this.userService = userService;
}
}
2.Setter方法注入 在UserController这个类中注入了userService这个对象属性
public class UserController {
private UserService userService;
public void setUserService(UserService userService) {
this.userService = userService;
}
}
3.注解注入
public class UserController {
@Autowired
private UserService userService;
}