通过Spring提供的IoC容器,我们可以将对象之间的依赖关系交由Spring进行控制,避免硬编码所造成的过度程序耦合。有了Spring,用户不必再为单实例模式类、属性文件解析等这些很底层的需求编写代码,可以更专注于上层的应用。
通过Spring提供的AOP功能,方便进行面向切面的编程,,许多不容易用传统OOP实现的功能可以通过AOP轻松应付。
在Spring中,我们可以从单调烦闷的事务管理代码中解脱出来,通过声明式方式灵活地进行事务的管理,提高开发效率和质量。
可以用非容器依赖的编程方式进行几乎所有的测试工作,在Spring里,测试不再是昂贵的操作,而是随手可做的事情。例如:Spring对Junit4支持,可以通过注解方便的测试Spring程序。
Spring不排斥各种优秀的开源框架,相反,Spring可以降低各种框架的使用难度,Spring提供了对各种优秀框架(如Struts,Hibernate、Hessian、Quartz)等的直接支持。
Spring对很多难用的Java EE API(如JDBC,JavaMail,远程调用等)
提供了一个薄薄的封装层,通过Spring的简易封装,这些Java EE API的使用难度大为降低。
Spring的源码设计精妙、结构清晰、匠心独运,处处体现着大师对Java设计模式灵活运用以及对Java技术的高深造诣。Spring框架源码无疑是Java技术的最佳实践范例。如果想在短时间内迅速提高自己的Java技术水平和应用开发水平,学习和研究Spring源码将会使你收到意想不到的效果。
IOC:Inversion of Control(控制反转)
控制反转:将对象的创建权反转给(交给)Spring。
传统开发模式 业务和实现类过于紧密,底层业务要修改源代码
通过工厂可以实现,接口与实现业务的分离
在工厂内部使用配置文件加载
通常名称起为 applicationContext.xml
<?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">
</beans>
public interface UserDao {
public void save();
public void delete();
}
public class UserDaoMysqlImpl implements UserDao {
@Override
public void save() {
System.out.println("mysql-save");
}
@Override
public void delete() {
System.out.println("mysql-delete");
}
}
public class UserDaoOracleImpl implements UserDao {
@Override
public void save() {
System.out.println("oracle-save");
}
@Override
public void delete() {
System.out.println("oracle-delete");
}
}
<?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">
<!-- id: 为自己起的名称; class:为接口实现类的全路径 -->
<bean id="userDao" class="com.xzh.demo1.UserDaoMysqlImpl"/>
</beans>
public class UserTest {
@Test
public void test(){
// 1.加载配置文件
ApplicationContext applicationContext =
new ClassPathXmlApplicationContext("applicationContext.xml");
// 2.根据id获取对象
UserDao userDao = (UserDao)applicationContext.getBean("userDao");
userDao.save();
userDao.delete();
}
}
UserDaoOracleImpl.java 新增属性 name
public class UserDaoOracleImpl implements UserDao {
public String name;
@Override
public void save() {
System.out.println("oracle-save");
}
@Override
public void delete() {
System.out.println("oracle-delete");
}
}
传统方式:
@Test
public void test2(){
UserDaoOracleImpl userDaoOracle = new UserDaoOracleImpl();
userDaoOracle.name = "IT";
System.out.println(userDaoOracle.name);
}
1.实现类当中的属性要提供set方法
public class UserDaoOracleImpl implements UserDao {
public String name;
// 依赖注入需要提供set方法
public void setName(String name) {
this.name = name;
}
@Override
public void save() {
System.out.println("oracle-save");
}
@Override
public void delete() {
System.out.println("oracle-delete");
}
}
2.在配置文件当中配置依赖注入
<!-- id: 为自己起的名称; class:为接口实现类的全路径 -->
<bean id="userDao" class="com.xzh.demo1.UserDaoOracleImpl">
<property name="name" value="IT666"/>
</bean>
测试
@Test
public void test2() {
// 1.加载配置文件
ApplicationContext applicationContext =
new ClassPathXmlApplicationContext("applicationContext.xml");
UserDaoOracleImpl obj = (UserDaoOracleImpl) applicationContext.getBean("userDao");
System.out.println(obj.name);
}
使用了约束中的唯一约束。里面不能出现特殊字符的
没有使用约束中的唯一约束。里面可以出现特殊字符。
Bean被初始化的时候执行的方法
Bean被销毁的时候执行的方法(Bean是单例创建,工厂关闭)
Person 类
public class Person {
public String name;
public void setName(String name) {
this.name = name;
}
public void init(){
System.out.println("init");
}
public void destroy(){
System.out.println("destroy");
}
}
applicationContext.xml 文件中增加配置
<!-- init-method:对象创建时,指定调用的方法;destroy-method:对象销毁时,指定调用的方法 -->
<bean id="person" class="com.xzh.demo2.Person" init-method="init"
destroy-method="destroy">
<property name="name" value="IT888" />
</bean>
编写测试类
@Test
public void test() {
// 加载 核心配置文件 会帮你创建对象 所有的对象
ClassPathXmlApplicationContext applicationContext =
new ClassPathXmlApplicationContext("applicationContext.xml");
Person person1 = (Person) applicationContext.getBean("person");
Person person2 = (Person) applicationContext.getBean("person");
System.out.println(person1); // 单例,每次获取的地址都相同
System.out.println(person2);
System.out.println(person1.name);
// 使用单例:关闭工厂 (所有的对象都 会销毁)
applicationContext.close();
}
测试结果
init
com.xzh.demo2.Person@8e24743
com.xzh.demo2.Person@8e24743
IT888
destroy
public class User {
public User() {
super();
System.out.println("默认构造方法");
}
}
applicationContext.xml 配置:
<bean id="user" class="com.xzh.demo3.User"></bean>
测试类:
@Test
public void test(){
ApplicationContext applicationContext = new
ClassPathXmlApplicationContext("applicationContext.xml");
User user = (User)applicationContext.getBean("user");
System.out.println(user);
}
public class User {
public static User createUser() {
System.out.println("调用了createUser----");
return new User();
}
}
applicationContext.xml 配置:
<bean id="user" class="com.xzh.demo3.User" factory-method="createUser"></bean>
测试类:
@Test
public void test(){
ApplicationContext applicationContext = new
ClassPathXmlApplicationContext("applicationContext.xml");
User user = (User)applicationContext.getBean("user");
System.out.println(user);
}
public class User {
public static User createUser() {
System.out.println("调用了createUser----");
return new User();
}
}
applicationContext.xml 配置:
<bean id="user" class="com.xzh.demo3.User" factory-method="createUser"></bean>
<bean id="user2" class="com.xzh.demo3.User" factory-bean="user"></bean>
测试类:
@Test
public void test(){
ApplicationContext applicationContext = new
ClassPathXmlApplicationContext("applicationContext.xml");
User user = (User)applicationContext.getBean("user2");
System.out.println(user);
}
原文:https://www.cnblogs.com/xzh0717/p/10836233.html