一.自动注入
- 在 Spring 配置文件中对象名和 ref=”id”id 名相同使用自动注入,可以不配置
<property/>
- 两种配置办法
2.1 在<bean>
中通过 autowire=”” 配置,只对这个<bean>
生效
2.2 在<beans>
中通过 default-autowire=””配置,表当当前文件中所有<bean>
都是全局配置内容 - autowire=”” 可取值
3.1 default: 默认值,根据全局 default-autowire=””值.默认全局和局部都没有配置情况下,相当于 no
3.2 no: 不自动注入
3.3 byName: 通过名称自动注入.在 Spring 容器中找类的 Id
3.4 byType: 根据类型注入.
3.4.1 spring 容器中不可以出现两个相同类型的<bean>
3.5 constructor: 根据构造方法注入.
3.5.1 提供对应参数的构造方法(构造方法参数中包含注入对戏那个)
3.5.2 底层使用 byName, 构造方法参数名和其他<bean>
的 id相同.
二. Spring 中加载 properties 文件
- 在 src 下新建 xxx.properties 文件
- 在 spring 配置文件中先引入 xmlns:context,在下面添加
2.1 如果需要记载多个配置文件逗号分割
<context:property-placeholder
location="classpath:db.properties"/>
- 添加了属性文件记载,并且在中开启自动注入注意的地方
3.1 SqlSessionFactoryBean 的 id 不能叫做 sqlSessionFactory
3.2 修改
3.2.1 把原来通过ref引用替换成value赋值,自动注入只能影响ref,不会影响 value 赋值
<bean class="org.mybatis.spring.mapper.MapperScannerConfigurer">
<property name="basePackage" value="com.bjsxt.mapper"></property>
<property name="sqlSessionFactoryBeanName" value="factory"></property>
</bean>
- 在被Spring管理的类中通过@Value(“${key}”)取出properties中内容
4.1 添加注解扫描
<context:component-scan base-package="com.bjsxt.service.impl">
</context:component-scan>
4.2 在类中添加
4.2.1 key 和变量名可以不相同
4.2.2 变量类型任意,只要保证 key 对应的 value 能转换成这个类型就可以.
@Value("${my.demo}")
private String test;
三.scope 属性
<bean>
的属性,- 作用:控制对象有效范围(单例,多例等)
<bean/>
标签对应的对象默认是单例的.
3.1 无论获取多少次,都是同一个对象- scope 可取值
4.1 singleton 默认值,单例
4.2 prototype 多例,每次获取重新实例化
4.3 request 每次请求重新实例化
4.4 session 每个会话对象内,对象是单例的.
4.5 application 在 application 对象内是单例
4.6 global session spring 推 出 的 一 个 对 象 , 依 赖 于spring-webmvc-portlet ,类似于 session
四.单例设计模式
- 作用: 在应用程序有保证最多只能有一个实例.
- 好处:
2.1 提升运行效率.
2.2 实现数据共享. 案例:application 对象 - 懒汉式
3.1 对象只有被调用时才去创建.
3.2 示例代码
public class SingleTon {
//由于对象需要被静态方法调用,把方法设置为 static
//由于对象是 static,必须要设置访问权限修饰符为 private ,
如果是 public 可以直接调用对象,不执行访问入口
private static SingleTon singleton;
/**
* 方法名和类名相同
* 无返回值.
*
*
* 其他类不能实例化这个类对象
*
* 对外提供访问入口
*/
private SingleTon(){}
/**
* 实例方法,实例方法必须通过对象调用
*
* 设置方法为静态方法
*
*
* @return
*/
public static SingleTon getInstance(){
//添加逻辑如果实例化过,直接返回
if(singleton==null){
/*
* 多线程访问下,可能出现 if 同时成立的情况,添加锁
*/
synchronized (SingleTon.class) {
//双重验证
if(singleton==null){
singleton = new SingleTon();
}
}
}
return singleton;
}
}
3.3 由于添加了锁,所以导致效率低.
4. 饿汉式
4.1 解决了懒汉式中多线程访问可能出现同一个对象和效率低问题
4.1 解决了懒汉式中多线程访问可能出现同一个对象和效率低问题
public class SingleTon {
//在类加载时进行实例化.
private static SingleTon singleton=new SingleTon();
private SingleTon(){}
public static SingleTon getInstance(){
return singleton;
}
}