主要是两个功能:
(1)创建对象 ,不再使用new 关键字来创建对象,而是使用xml文件或者注解来创建对象,其实主要还是通过注解来创建,xml文件太繁琐了,主要是通过@Component注解,@Controller注解,@Service,@Dao注解来创建对象,然后需要引入对象就使用@Autowired注解
(2)管理对象之间的依赖关系
对象之间的依赖关系(其中一个类中有属性是对象属性),比如下面:
class A
{
B b;
C c;
}
此时我们说类A依赖类B和类C
主方法代表的是用户
service层和dao层代表的是程序员
下面的程序就是属于主动权在程序员手上,用户无法操作,只能通过程序员更改service层代码的方式调用不同的方法(主方法不动,service层动)
控制反转就是将主动权交给用户,用户通过在主方法中更改代码(service层代码不改),来调用不同的方法(主方法里动,service层不动)
实际上spring框架使得我们既不用在主方法里做修改,也不用在service层里做修改,只需要在xml文件里面做修改就行
业务层service不做其他的事情,就做一件事:调用dao层去数据库查询
主方法中的代码是不用变的,需要将service层的①换成②,就可以从调用UserDaoImpl类的getUser方法变成调用UserDaoMysqImpl类的getUser方法
每次用户的请求发生改变,程序员就需要去改动service层的代码,这不是优秀的程序
这就是IOC的原型,主动权控制权不再在程序员手上,而是在用户手上
1.控制反转是一种思想:把对象的创建,对象属性的赋值,对象之间的关系管理都交给代码之外的容器来实现
控制:创建对象,给对象的属性赋值,管理对象之间的关系
正转:开发人员在代码中用new的形式创建一个对象(比如Student student=new Student()),并且给这个对象的属性赋值,管理对象之间的关系
反转:交给代码之外的容器(所谓代码之外的意思就是,就是不用在java类中写代码给属性赋值,而是在xml配置文件中给属性赋值),由容器来代替开发人员来进行创建对象,给对象的属性赋值,管理对象之间的关系
spring就是这样一个容器,可以替代开发人员来进行创建对象,给对象的属性赋值,管理对象之间的关系
2.IOC思想的一种体现:
在Servlet中:当你在web.xml文件中写下:
<servlet-name> myservlet </servlet-name>
<servlet-class>com.bjpowernode.controller.MyServlet<servlet-class>
此时你虽然没有MyServlet myservlet=new MyServlet(),但是此时myservlet确实是一个 MyServlet对象
这说明,tomcat服务器在后台帮助你创建出来这个MyServlet对象
tomcat服务器也是一个容器,帮助你创建对象,并且把创建出来的对象存储在这个容器里面
tomcat这个容器里还有其他对象,比如Listener对象,Filter对象......
另外注意一下:
com.bjpowernode.controller.MyServlet改成com.bjpowernode.controller.MyServlet1,那么此时myservlet就不是一个MyServlet对象,而是一个MyServlet1对象了
3.spring这个框架使用DI(dependen injection,依赖注入)来实现IOC
4.spring容器管理的Java对象叫作bean
<beans>
<bean id="" class="">
</bean>
</beans>
spring根据id,class创建对象,把对象放入到spring的map里面,map.put(id,对象)
id可以没有(提供默认的),class必须有,而且必须是具体到哪个包下的哪个类(全限定名称)
5.获取容器内的信息(容器内有几个对象,每个对象的名字)
(1)在xml配置文件中定义了两个bean(所以创建出容器对象后,容器内有两个java对象)
<bean id="someService" class="com.bjpowernode.service.impl.SomeServiceImpl">
</bean>
<bean id="someService1" class="com.bjpowernode.service.impl.SomeServiceImpl">
</bean>
(2)编写代码:
String config="beans.xml";
ApplicationContext ctx=new ClassPathXmlApplicationContext(config);
int nums=ctx.getBeanDefinitionCount();
System.out.println("容器内有多少个bean对象="+nums);
//容器中对象的名称
String names[]=ctx.getBeanDefinitionNames();
for (String name:names)
{
System.out.println("容器中对象的名称=" + name);
}