第二章:装配 Bean
--------------------------------------------------------------------------------
1. <ref>标签中的 bean, local, parent 三个属性的区别(P53)
2. <list><value...</list>和<set><value...</set>可以换着用都可以为 List, Set 以及数组属性赋值(P55)
3. <map>属性用 spring 进行装匹时 key 值只能是字符串类型,不过一般能满足要求(P55)
4. 装配 map 属性要用 <entry key="key1"><value>foo</value></entry>, 而装匹 properties 属性可以写成 <prop key="key1">foo</prop>, 这是因为 properties 的值总是字符串,而 map 中很随意(P55)
5. 用 <property name="foo"><null/></property> 形式设置属性为 null, 区别为字符串 "null"(P56)
6. 通过构造函数注入依赖时,对多参数需要借助于 index 或 type 属性来指定对应哪个参数,index 属性能应付所有情况(P58)
7. 可为 bean 设置 autowire为四个值, byName, byType, constructor, autodetect, 四种方式自动装匹;也可以在 <beans> 中设置 default-autowire 属性。手动和自动可以混合使用,手动优先。你应该清楚自己在做什么,所以不建议用自动装配(P61)
8. BeanPostProcessor的方法 postProcessBeforeInitialization 在 bean 初始化之前调用,postProcessAfterInitialization 是在 bean 初始化之后调用,需要注册到 BeanFactory 上,如 factory.addBeanPostProcessor(new BeanPostProcessor(){...})。内置的 ApplicationContextAwareProcessor 注册在了 AbstractApplicationContext 上了(P64)
9. BeanFactoryPostProcessor 是在 Bean 工厂载入所有 Bean 定义后,实例化 Bean 之前作处理。如果是 AbstractApplicationContext ,那么只需要配置 <bean id="myBeanFactoryPostProcessor" class="com.unmi.MyBeanFactoryPostProcessor"/>, 则会自动注册这个,原有的 BeanFactoryPostProcessor 不可用了,不需要显示式的调用 addBeanFactoryPostProcessor 方法(P67)
10. 可用 PropertyPlaceholderConfigurer 载入属性文件,然后在其他引用 value 的地方用 ${database.url} 的方式引用(P70)
11. 用 CustomEditorConfigurer 注册自己的 PropertyEditorSupport 关联特定的 bean 属性的处理,可了解 Spring 有哪些内置的 PropertyEditorSupport(P72)
12. Spring 用 ResourceBundleMessageSource 处理国际化,配置成
<bean id="messageSource" class="org.springframework.context.support.ResourceBundleMessageSource">
<property name="basename">
<value>trainingtext</value>
</property>
</bean>
<bean id="messageSource" class="org.springframework.context.support.ResourceBundleMessageSource">
<property name="basename">
<value>trainingtext</value>
</property>
</bean>
会读取 trainingtext.prperties, trainingtext_en_US.properties 等。
用 Sring text = context.getMessage("button.submit", new Object[0],locale); 或 <sping:message code="button.submit"/> 读取(P73)
13. 监听事件,配置实现了ApplicationListener的Bean,容器会自动注册它,发布ApplicationEvent时由它处理,事件的处理是同步的(P74)
14. Bean 实现了 BeanNameAware, BeanFactoryAware 或 ApplicationContextAware 可以感知它自己或所处环境的信息,但这样做却让 Bean 与 Spring 框架耦合起来了(P76)
第三章:创建切面
--------------------------------------------------------------------------------
15. AOP: spring 有两种代理创建方式,对接口方法用JDK的java.lang.reflect.Proxy类创建代理,对于未实现接口的借助于 CGLIB 库生成目标对象的子类,标记为 final 的方法不能被通知,因为子类中不能覆写该方法(P83)
16. Spring 只支持方法连接点,应该也是秉着够用就行的道理,直接用 AspectJ 将能做十分细致的活,Spring 2.x 用上了 AspectJ。(P84)
17. MyEclipse 提供了一种快捷方式来写Bean的配置,从左树上把类拖到打开的 Spring 的配置文件中依提示行事即可,实际使用中看是否真正实用
18. 在 MethodBeforeAdvice中可以抛异常(或System.exit(),这有点过份了) 阻止目标方法的执行,如果此时抛出的异常是 RuntimeException 或者目标方法申明的异常,将会被 Spring 框架捕获(P86)
19. MethodInterceptor 能控制目标方法是否真的被调用,用 methodInvocation.proceed() 调用目标方法(P89)
20. MethodInterceptor 可以返回一个与目标方法不同的对象,但也必须是兼容的,否则出现 ClassCastException 异常(P89)
21. 实现接口 ThrowsAdvice 的类,必须至少有一个如下形式方法:
1)void afterThrowing(Throwable throwable)
2)void afterThrowing(Method method, Object[] args, Object target, Throwable throwable)
在 ThrowsAdvice 并没有象 MethodBeforeAdvice, MethodAfterAdvice 和 MethodInterceptor 定义了要实现的方法,只是一个不成文的约定,不知作者是如何考虑的,怕定义了两个方法后实现类要实现两个方法(可能只需用到一个方法)而麻烦吗?那至少可以弄一个 ThrowsAdviceAdapter 的东西,Spring 中还确实有这玩艺,但不是那么回事。
这种 ThrowsAdvice 对实现类不成文的规定,让在 IDE 中写代码不方便,也容易产生错误(P90)
22. 当你的 ThrowsAdvice 同时实现了上面两个方法时,只有参数多的那个方法有效,只实现第一个方法也是可以的,所以在 ThrowsAdvice 的源代码中只提到要实现第二个方法,所以我就更想不能了,为什么在接口 ThrowsAdvice 中不定义这个方法呢?(P90)
23. 记录几个书中错误:54页的java.awt应该是java.util。94页的maidService配置中的frequentCustomerAdvisor应该是 frequentCustomerPointcutAdvisor。108页,后面两个 proxyInterfaces 应该是 interceptorNames
24. 用 NameMatchMethodPointAdvisor 能简单的用通配符控制切入点,但要细致的控制切入点就要用 RegexpMethodPointcutAdvisor 结合正则表达式了, 它可含有类名信息,而 NameMatchMethodPointAdvisor只需考虑方法名的匹配(P90)
25. 动态切入点的配置方法与静态切入点略有不同,需要申明一个ControlFlowPointcut的Bean(Pointcut)作为DefaultPointcutAdvisor的pointcut属性,然后这个advisor配置到ProxyFactoryBean的interceptorNames,所以想,既然是叫做DefaultPointcutAdvisor,那么是不是别的Pointcut也可以通过这种方式来配置呢?动态切入点很损耗性能,非必要是不用,对JDK1.4会慢5位,对JDK1.3会慢10,对于JDK1.5恐怕也好不到哪儿去(P96)
26. 觉得 Spring 的引用 IntroductionInterceptor 用起来特麻烦,远没有直接用 AspectJ 来的方便与简练(P100)
27. 配置 ProxyFactoryBean 时不指定 proxyInterfaces 属性,直接指定 target 为Class,则会用CGLIB生成目标类的子类。即使指定的 proxyInterfaces 属性,设置 ProxyTargetClass 属性为 true,也会用 CGLIB 生成目标类的子类,而不是用JDK的动态代理(P106)
28. 配置 ProxyFactoryBean 时可以把 target 目标对象配置为interceptorNames的最后一个属性(P108)
29. 强大的自动代理:BeanNameAutoProxyCreator 和 DefaultAdvisorAutoProxyCreator。DefaultAdvisorAutoProxyCreator实现了 BeanPostProcessor 接口,它只能与 Advisor 配合使用,自动的处理所有的 Advisor (P109)
30. 看到29条中的自动代理,让我回想起可以为一批 Bean 批量的增加 toString() 方法,只是那些 bean 必须通过 getBean()得来才能看到效果
分享到:
相关推荐
Spring in Action中文清晰版(带阅读笔记). Spring in Action中文清晰版(带阅读笔记).
Spring in Action中文清晰版(带阅读笔记)
### Spring In Action笔记100例精要解析 #### 1. `<ref>`标签中的`bean`, `local`, `parent`三个属性的区别 在Spring框架中,`<ref>`标签用于表示一个对象引用,通常用来注入另一个Bean。该标签包含三个重要的属性...
Spring in Action 中文 清晰版 (带阅读笔记)(共压缩4分卷) 此第3分卷 是扫描版的 感谢分享的兄弟
### Spring in Action 学习笔记知识点总结 #### 1. Spring 框架基础 ##### 1.1 Spring 概述 - **轻量级**:Spring 的“轻量级”主要体现在其对资源消耗较少,同时具备低入侵性。在基于 Spring 开发的应用中,业务...
《Spring in Action》是一本深度剖析Spring框架的权威著作,其中文清晰版为中国的开发者提供了便利,便于理解和学习。本书全面覆盖了Spring的核心概念和技术,包括依赖注入、AOP(面向切面编程)、数据访问、Web开发...
Spring in Action 中间带有读书笔记, 第2部分共4部分
标题和描述均提到了“spring指南学习笔记”,这意味着文档聚焦于Spring框架的学习心得与关键概念。Spring是一个开源的Java企业级应用框架,以其强大的依赖注入(Dependency Injection, DI)和面向切面编程(Aspect ...
以下将详细介绍Spring学习笔记中的主要知识点。 **面向抽象编程** 面向抽象编程是一种设计原则,强调在代码中使用接口或抽象类,而不是具体实现类。这使得系统更具有灵活性,易于扩展和维护。在Spring框架中,我们...
Spring框架是Java开发中不可或缺的一部分,它以其强大的依赖注入(IOC)和面向切面编程(AOP)功能闻名。这份"spring-note spring 读书笔记"深入探讨了Spring的核心概念以及如何与其他流行技术如JDBC、Hibernate、...
Spring in Action 中间带有读书笔记 第4部分共4部分
Spring in Action 中间带有读书笔记,第3部分共4部分
#### 一、Spring框架概述 Spring是一个开源的Java平台框架,旨在简化企业级应用程序的开发。它通过提供一套轻量级的基础设施和服务,帮助开发者更容易地构建稳定、可扩展的应用程序。Spring的核心优势在于它支持...
读书笔记:《Spring Boot实战》Spring Boot in Action
Spring in Action 中文 清晰版 (带阅读笔记).part2
Spring in Action 中文 清晰版 (带阅读笔记).part1