IOC
IoC:Inverse Of Control。控制反转。
4种方式:
1.构造方法:<bean class="类的全路径" ><construct-args ></bean>
2.静态工厂:<bean class="静态工厂全路径" factory-method="getUser"/>
UserFactory.getUser();
class UserFactory{
User getUser(){
return new User();
}
}
3.实例化工厂
UserFactory factory = new UserFactory();
User user = factory.getUser()
<bean id="factory" class="UserFactory类的全路径" />
<bean id="user" factory-ref="factory" factory-method="getUser"/>
4.工厂bean FactoryBean接口
<bean id="User" class="FactoryBean的实现类的全路径"/>
DI:Dependency Injection。依赖注入。
3种方式,但是spring支持两种:
1.setter注入
2.构造方法
3.接口注入
IoC四种注解:
1.对象初始化注解
@Component 通用注解,不推荐使用,要用的话,任何类的头上都能使用,但是这个类到底是干嘛用得就不知道了。
@Controller 控制层使用
@Service 服务层使用
@Repository 数据访问层的注解
2.依赖注入
@Resource 这个注解属于J2EE的,默认按name注入,可以通过name和type属性进行选择性注入
@Autowired spring的注解,默认按type注入
@Qualifier spring的注解,按名字注入 一般当出现两个及以上bean时,不知道要注入哪个,作为@Autowired()的修饰用
3.生命周期
@PostConstruct 构造方法执行之后执行
@PreDestroy 对象销毁之前执行
4.作用域
@Scope(Singleton prototype request session globalsession)
以下转自
一分钟学会spring注解之@Scope注解
https://blog.51cto.com/u_4247649/2118351
1,@Scope注解是什么
@Scope注解是springIoc容器中的一个作用域,在 Spring IoC 容器中具有以下几种作用域:基本作用域singleton(单例)、prototype(多例),Web 作用域(reqeust、session、globalsession),自定义作用域
a.singleton单例模式 -- 全局有且仅有一个实例
b.prototype原型模式 -- 每次获取Bean的时候会有一个新的实例
c.request -- request表示该针对每一次HTTP请求都会产生一个新的bean,同时该bean仅在当前HTTP request内有效
d.session -- session作用域表示该针对每一次HTTP请求都会产生一个新的bean,同时该bean仅在当前HTTP session内有效
e.globalsession -- global session作用域类似于标准的HTTP Session作用域,不过它仅仅在基于portlet的web应用中才有意义
2,@Scope注解怎么使用
直接在bean对象方法上增加@Scope注解就可以如下:
/**
* 定义一个bean对象
* @return
*/
@Scope
@Bean(value="user0",name="user0",initMethod="initUser",destroyMethod="destroyUser")
public User getUser(){
System.out.println("创建user实例");
return new User("张三",26);
}
@Scope注解默认的singleton实例,singleton实例的意思不管你使用多少次在springIOC容器中只会存在一个实例,演示如下只打印了一次创建实例:
AnnotationConfigApplicationContext applicationContext2 = new AnnotationConfigApplicationContext(MainConfig.class);
User bean2 = applicationContext2.getBean(User.class);
System.out.println("实例1 === "+bean2);
User bean3 = applicationContext2.getBean(User.class);
System.out.println("实例2 === "+bean3);
创建user实例
实例1 === User [userName=张三, age=26]
实例2 === User [userName=张三, age=26]
接下来把实例类型改为prototype如下:
@Scope(value="prototype")
运行结果如下:
创建user实例
实例1 === User [userName=张三, age=26]
创建user实例
实例2 === User [userName=张三, age=26]
注:这边只演示了我们常用的两种作用域,其他的大家可以下去自己试试
3,@Scope注解的使用场景
几乎90%以上的业务使用singleton单实例就可以,所以spring默认的类型也是singleton,singleton虽然保证了全局是一个实例,对性能有所提高,但是如果实例中有非静态变量时,会导致线程安全问题,共享资源的竞争
当设置为prototype时:每次连接请求,都会生成一个bean实例,也会导致一个问题,当请求数越多,性能会降低,因为创建的实例,导致GC频繁,gc时长增加