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时长增加

  • 1
    点赞
  • 11
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值