`
DoubleEO
  • 浏览: 154495 次
  • 性别: Icon_minigender_1
  • 来自: 北京
社区版块
存档分类
最新评论

spring in action学习笔记 1 (许多自己的理解,欢迎拍砖)

阅读更多
1.我所知道的aop
    初看aop,上来就是一大堆术语,而且还有个拉风的名字,面向切面编程,都说是OOP的一种有益补充等等。一下子让你不知所措,心想着:怪不得很多人都和我说aop多难多难。当我看进去以后,我才发现:它就是一些java基础上的朴实无华的应用,包括ioc,包括许许多多这样的名词,都是万变不离其宗而已。
2.为什么用aop
    1就是为了方便,看一个国外很有名的大师说,编程的人都是“懒人”,因为他把自己做的事情都让程序做了。用了aop能让你少写很多代码,这点就够充分了吧
    2就是为了更清晰的逻辑,可以让你的业务逻辑去关注自己本身的业务,而不去想一些其他的事情,这些其他的事情包括:安全,事物,日志等。
    3.那些aop的术语
    初看这么多术语,一下子都不好接受,慢慢来,很快就会搞懂。
    1.通知(Advice)
    就是你想要的功能,也就是上面说的 安全,事物,日志等。你给先定义好把,然后在想用的地方用一下。
    2.连接点(JoinPoint)
    这个更好解释了,就是spring允许你使用通知的地方,那可真就多了,基本每个方法的前,后(两者都有也行),或抛出异常时都可以是连接点,spring只支持方法连接点.其他如aspectJ还可以让你在构造器或属性注入时都行,不过那不是咱关注的,只要记住,和方法有关的前前后后(抛出异常),都是连接点。
    3.切入点(Pointcut)
    上面说的连接点的基础上,来定义切入点,你的一个类里,有15个方法,那就有几十个连接点了对把,但是你并不想在所有方法附近都使用通知(使用叫织入,以后再说),你只想让其中的几个,在调用这几个方法之前,之后或者抛出异常时干点什么,那么就用切点来定义这几个方法,让切点来筛选连接点,选中那几个你想要的方法。
    4.切面(Aspect)
    切面是通知和切入点的结合。现在发现了吧,没连接点什么事情,连接点就是为了让你好理解切点,搞出来的,明白这个概念就行了。通知说明了干什么和什么时候干(什么时候通过方法名中的before,after,around等就能知道),而切入点说明了在哪干(指定到底是哪个方法),这就是一个完整的切面定义。
    5.引入(introduction)
    允许我们向现有的类添加新方法属性。这不就是把切面(也就是新方法属性:通知定义的)用到目标类中吗
    6.目标(target)
    引入中所提到的目标类,也就是要被通知的对象,也就是真正的业务逻辑,他可以在毫不知情的情况下,被咱们织入切面。而自己专注于业务本身的逻辑。
    7.代理(proxy)
    怎么实现整套aop机制的,都是通过代理,这个一会给细说。
    8.织入(weaving)
    把切面应用到目标对象来创建新的代理对象的过程。有3种方式,spring采用的是运行时,为什么是运行时,后面解释。
关键就是:切点定义了哪些连接点会得到通知

   4.我所理解的aop原理

    spring用代理类包裹切面,把他们织入到Spring管理的bean中。也就是说代理类伪装成目标类,它会截取对目标类中方法的调用,让调用者对目标类的调用都先变成调用伪装类,伪装类中就先执行了切面,再把调用转发给真正的目标bean。
    现在可以自己想一想,怎么搞出来这个伪装类,才不会被调用者发现(过JVM的检查,JAVA是强类型检查,哪里都要检查类型)。
    1.实现和目标类相同的接口,我也实现和你一样的接口,反正上层都是接口级别的调用,这样我就伪装成了和目标类一样的类(实现了同一接口,咱是兄弟了),也就逃过了类型检查,到java运行期的时候,利用多态的后期绑定(所以spring采用运行时),伪装类(代理类)就变成了接口的真正实现,而他里面包裹了真实的那个目标类,最后实现具体功能的还是目标类,只不过伪装类在之前干了点事情(写日志,安全检查,事物等)。
    这就好比,一个人让你办件事,每次这个时候,你弟弟就会先出来,当然他分不出来了,以为是你,你这个弟弟虽然办不了这事,但是他知道你能办,所以就答应下来了,并且收了点礼物(写日志),收完礼物了,给把事给人家办了啊,所以你弟弟又找你这个哥哥来了,最后把这是办了的还是你自己。但是你自己并不知道你弟弟已经收礼物了,你只是专心把这件事情做好。
   
    顺着这个思路想,要是本身这个类就没实现一个接口呢,你怎么伪装我,我就压根没有机会让你搞出这个双胞胎的弟弟,那么就用第2种代理方式,创建一个目标类的子类,生个儿子,让儿子伪装我

    2.生成子类调用,这次用子类来做为伪装类,当然这样也能逃过JVM的强类型检查,我继承的吗,当然查不出来了,子类重写了目标类的所有方法,当然在这些重写的方法中,不仅实现了目标类的功能,还在这些功能之前,实现了一些其他的(写日志,安全检查,事物等)。
   这次的对比就是,儿子先从爸爸那把本事都学会了,所有人都找儿子办事情,但是儿子每次办和爸爸同样的事之前,都要收点小礼物(写日志),然后才去办真正的事。当然爸爸是不知道儿子这么干的了。 这里就有件事情要说,某些本事是爸爸独有的(final的),儿子学不了,学不了就办不了这件事,办不了这个事情,自然就不能收人家礼了。

   前一种兄弟模式,spring会使用JDK的java.lang.reflect.Proxy类,它允许Spring动态生成一个新类来实现必要的接口,织入通知,并且把对这些接口的任何调用都转发到目标类。

    后一种父子模式,spring使用CGLIB库生成目标类的一个子类,在创建这个子类的时候,spring织入通知,并且把对这个子类的调用委托到目标类。
    相比之下,还是兄弟模式好些,他能更好的实现松耦合,尤其在今天都高喊着面向接口编程的情况下,父子模式只是在没有实现接口的时候,也能织入通知,应当做一种例外。

初学aop对aop术语和原理上的一些总结
分享到:
评论
39 楼 taobuguo 2009-09-30  
DoubleEO 写道
jcbufresh 写道
学习了,虽然对aop有所了解,但看了楼主的理解感觉跟亲切。
关于代理的理解,看到比较亲切的就是阎宏的《java与模式》和楼主的了。
很多介绍aop的书籍里充斥着大量的专业名词,书看完了已被这些名词给
弄晕了。喜欢的还是议论文的三段式,提出问题,解决问题,证明问题。
为什么会产生这种技术?因为什么问题而有了这种技术?
这种技术是怎么解决这个问题的?
这种技术和其他的技术比较,在解决这个问题时有什么优势?
最好是在讲解的时候能更通俗,更形象。
感谢楼主的分享,赞一个!


看了你对我的评价,我湿了~

你是男的还是女的啊,这么容易湿
38 楼 myloveiscomealone 2009-09-28  
DoubleEO 写道
iranger 写道
麦田守望者 写道

Advice应该叫增强吧

哥儿们你是不是看了陈的那本Spring?Advice在英文里就是通知的意思,绝对没有增强的意思,可以翻翻字典。
陈把它叫做增强是从功能上来解释的,因为一个Advice的作用是使目标类有了新的功能,就像增强了目标类一样,所以他认为叫增强更合适

我也觉得是,英文毕竟不是母语,所以叫advice就好了~陈那本大厚你读完了吗?那可这是很厚啊


什么咯,advice就是增强的意思。也称为通知,分为前置通知,后置通知,还有环绕通知。我来说说我对AOP的理解吧:AOP的意思就是面面向方面编程,它是继OOP后又一具有理程碑意义的一种编程思想;那么什么是方面呢?方面的意思就是分散在系统周围,在实现业务逻辑的时候需关注的关注点,也叫切面!Spring由动态代理和静态代理,DI,Spring是一种通过溶器的方式管理业务逻辑,区别于业务方法管理。DI是依赖的意思。那么什么是依赖呢?比方说,一个类的定义会引起另外一个类的改变,或者一个类需要调用另外一个类里的某个方法,或者一个类需要发送消息给另外一个类,这时我们就说它们之间有依赖关系存在!AOP怎么为什么说具有理程碑意义呢?我来举个例子吧,如果我要用OOP去实现一台电脑,电脑的零件不多,用OOP很好去实现,但是如果我要用OOP去实现一台波音飞机(里面有上几个亿的零部件)这时OOP就显得苍白无力了,AOP很好的解决了这个问题,因为它最大的优点就是分离组件的实现和使用,就好比美国产一架波音飞机,它的材料来自世界各地,你中国给我生产玻璃,瑞士给我生产涡轮`````等!只要给一个标准(接口),因为Spring也是面向接口的,就可以去实现了!spring的本质就是一个溶器!
37 楼 ningmenglovesoft 2009-09-27  
我谁的书也没看过。我就在官网上看了文档。Java 现在比较流行ssh,可我工作几年还没用过ssh开发过一个项目。不好意思。路过
36 楼 caicop 2009-09-02  
lz对aop理解的很深啊,讲的很通俗易懂~~
35 楼 sesame 2009-08-25  
    前一种兄弟模式,spring会使用JDK的java.lang.reflect.Proxy类,它允许Spring动态生成一个新类来实现必要的接口,织入通知,并且把对这些接口的任何调用都转发到目标类。

    后一种父子模式,spring使用CGLIB库生成目标类的一个子类,在创建这个子类的时候,spring织入通知,并且把对这个子类的调用委托到目标类。


讲的不错!
34 楼 bojovi 2009-08-20  
楼主总结的很生动,看后对aop的理解变得清晰了许多
33 楼 wwyinhuabin 2009-08-08  
AOP 术语还是要自己写 ,才能明白啊
32 楼 hanwesley 2009-07-26  
太理论不太好   
31 楼 tianmo2008 2009-07-25  
spring in action 的每一章开头都是一片概念轰炸,看得头晕,aop那章也不例外,
我每章都是直接看他后面的例子,再回去看概念的.
不过确实是本好书,只要不在那些概念上钻牛角尖的话,看他的例子还是很通俗易懂的.
30 楼 hanwesley 2009-07-11  
不要硬翻译不久行了 按照英语理解 哈哈
29 楼 martinyuan 2009-07-10  
我最近也重新看了看Spring,感觉楼主对技术和生活的理解都很好,本来技术就源于生活的。呵呵。记的通俗(褒义)又牢固。希望能在出新帖。呵呵。加油!
28 楼 z494627 2009-07-04  
对我理解AOP很有帮助,非常感谢楼主!
27 楼 litianhai 2009-07-04  
写的不错 举得那个例子 比较好
26 楼 快乐让让 2009-07-01  
谢谢楼主!
25 楼 iranger 2009-03-06  
DoubleEO 写道
jcbufresh 写道
学习了,虽然对aop有所了解,但看了楼主的理解感觉跟亲切。
关于代理的理解,看到比较亲切的就是阎宏的《java与模式》和楼主的了。
很多介绍aop的书籍里充斥着大量的专业名词,书看完了已被这些名词给
弄晕了。喜欢的还是议论文的三段式,提出问题,解决问题,证明问题。
为什么会产生这种技术?因为什么问题而有了这种技术?
这种技术是怎么解决这个问题的?
这种技术和其他的技术比较,在解决这个问题时有什么优势?
最好是在讲解的时候能更通俗,更形象。
感谢楼主的分享,赞一个!


看了你对我的评价,我湿了~

看到楼主这句回复,我就往某些方面想了,我的思想已经被玷污了,我的心灵已经不再纯洁了~~~~~~
24 楼 kantery 2009-03-06  
DoubleEO 对AOP分析的很形象,学习收益了。
23 楼 oldman 2009-02-13  
非常形象,理解很容易,感谢。。。
22 楼 yinxiaoyong 2009-02-12  
不错,感觉确实比一些书上讲的亲切很多,呵呵,正准备学习Spring,之前只是接触过一点,这些概念之前也很模糊,这次刊例LZ的总结,思路清晰了许多,谢谢,希望LZ可以继续写这样优秀的文章哦。。。。。。。呵呵
21 楼 haopeng_haopeng 2009-02-12  
very good ,thank you

本当に どうもありがとうございます
20 楼 davidgrubby 2009-02-12  
讲的很不错啊~~~

相关推荐

Global site tag (gtag.js) - Google Analytics