没有合适的资源?快使用搜索试试~ 我知道了~
温馨提示
试读
18页
作为一个资深Java工程师,我发现《Spring 设计模式总结》PDF非常精彩,它深入剖析了Spring框架中的关键设计模式。例如,简单工厂模式通过BeanFactory展现,实现了松耦合和动态对象创建。工厂方法模式则通过FactoryBean接口展示,让对象创建更加灵活。单例模式保证了Bean实例的唯一性,而适配器模式和装饰器模式则提高了代码的可扩展性和可重用性。代理模式和观察者模式在Spring AOP和事件驱动模型中得到了广泛应用,提供了强大的切面和事件处理能力。策略模式和模板方法模式则分别提供了资源访问的灵活性和统一处理逻辑的框架。最后,责任链模式在Spring的AOP代理实现中发挥了重要作用,允许多个切面协调操作。这些模式共同构成了Spring框架的设计骨架,对于任何Java工程师来说,理解和掌握这些模式是提升自己架构设计能力的关键。
资源推荐
资源详情
资源评论
bean容器的启动阶段:
读取bean的配置,将bean元素分别转换成一个
BeanDefinition对象。
然后通过BeanDefinitionRegistry将这些bean注册到
beanFactory中,保存在它的一个ConcurrentHashMap中。
将BeanDefinition注册到了beanFactory之后,在这里
Spring为我们提供了一个扩展的切口,允许我们通过实现接口
BeanFactoryPostProcessor在此处来插入我们定义的代码。
典型的例子就是:PropertyPlaceholderConfigurer,我们一般在配置
数据库的dataSource时使用到的占位符的值,就是它注入进去的。
容器中bean的实例化阶段:
实例化阶段主要是通过反射或者CGLIB对bean进行实例化,在这个阶
段Spring又给我们暴露了很多的扩展点:
各种的Aware接口,比如BeanFactoryAware,对于实现了
这些Aware接口的bean,在实例化bean时Spring会帮我们注入对
应的BeanFactory的实例。
BeanPostProcessor接口,实现了BeanPostProcessor接口
的bean,在实例化bean时Spring会帮我们调用接口中的方法。
InitializingBean接口,实现了InitializingBean接口的
bean,在实例化bean时Spring会帮我们调用接口中的方法。
DisposableBean接口,实现了BeanPostProcessor接口的
bean,在该bean死亡时Spring会帮我们调用接口中的方法。
设计意义:
松耦合。可以将原来硬编码的依赖,通过Spring这个beanFactory这个
工厂来注入依赖,也就是说原来只有依赖方和被依赖方,现在我们引入
了第三方——spring这个beanFactory,由它来解决bean之间的依赖
问题,达到了松耦合的效果.
bean的额外处理。通过Spring接口的暴露,在实例化bean的阶段我们
可以进行一些额外的处理,这些额外的处理只需要让bean实现对应的
接口即可,那么spring就会在bean的生命周期调用我们实现的接口来
处理该bean。[非常重要]
2.工厂方法
实现方式:
FactoryBean接口。
实现原理:
实现了FactoryBean接口的bean是一类叫做factory的bean。其特点
是,spring会在使用getBean()调用获得该bean时,会自动调用该
bean的getObject()方法,所以返回的不是factory这个bean,而是这
个bean.getOjbect()方法的返回值。
例子:
典型的例子有spring与mybatis的结合。
代码示例:
说明:
我们看上面该bean,因为实现了FactoryBean接口,所以返回的不是
SqlSessionFactoryBean的实例,而是它的
SqlSessionFactoryBean.getObject()的返回值。
扩展:设计模式是什么鬼(工厂方法)
3.单例模式
Spring依赖注入Bean实例默认是单例的。
Spring的依赖注入(包括lazy-init方式)都是发生在
AbstractBeanFactory的getBean里。getBean的doGetBean方法调用
getSingleton进行bean的创建。
分析getSingleton()方法
1 publicObjectgetSingleton(StringbeanName){
2 //参数true设置标识允许早期依赖
3 returngetSingleton(beanName,true);
4 }
5 protectedObjectgetSingleton(StringbeanName,booleanallowEarl
yReference){
6 //检查缓存中是否存在实例
7 ObjectsingletonObject=this.singletonObjects.get(beanName);
8 if(singletonObject==null&&isSingletonCurrentlyInCreation(be
anName)){
9 //如果为空,则锁定全局变量并进行处理。
10 synchronized(this.singletonObjects){
11 //如果此bean正在加载,则不处理
12 singletonObject=this.earlySingletonObjects.get(be
anName);
13 if(singletonObject==null&&allowEarlyReference){
14 //当某些方法需要提前初始化的时候则会调用addSingleFactory方法将对应
的ObjectFactory初始化策略存储在singletonFactories
15 ObjectFactorysingletonFactory=this.singleton
Factories.get(beanName);
16 if(singletonFactory!=null){
剩余17页未读,继续阅读
资源评论
光芒软件工匠
- 粉丝: 789
- 资源: 64
上传资源 快速赚钱
- 我的内容管理 展开
- 我的资源 快来上传第一个资源
- 我的收益 登录查看自己的收益
- 我的积分 登录查看自己的积分
- 我的C币 登录后查看C币余额
- 我的收藏
- 我的下载
- 下载帮助
安全验证
文档复制为VIP权益,开通VIP直接复制
信息提交成功