IT修真院·小课堂丨互联网职业小课堂在线学习平台

课堂课题:

对Service返回的结果是否要打日志,应该打什么样的日志,为什么?

关联任务:

任务五

直播时间:

2018-09-26 15:30:00


课堂内容:

视频链接:

PPT链接:

提交按钮:

小课堂内容格式


标题:

【修真院xx(职业)小课堂】课题名称

开场语:

大家好,我是IT修真院XX分院第X期的学员XX,一枚正直纯洁善良的XX程序员,今天给大家分享一下,修真院官网XX(职业)任务X,深度思考中的知识点——XXX

(1)背景介绍:

背景介绍的时候,尽可能的要宽广,讲清楚来龙去脉,讲清楚为什么会需要这个技术。

(2)知识剖析:

讲知识点的时候,尽可能的成体系,学会成体系的去给别人介绍知识。现在很多做的都是零散的,没有分类。

(3)常见问题:

最少列出1个常见问题。

(4)解决方案:

写清楚常见问题的解决方案。

(5)编码实战:

尽可能的去寻找在真实项目中在用的。如果你能找到某个网站在用你说的知识点,这是最好的。学以致用,否则当成练习题就没有意义了。多准备一些demo,讲解过程中将知识点和demo结合,便于大家理解所讲解的知识点。

(6)拓展思考:

知识点之外的拓展思考,由分享人进行讲解,这些东西就是所谓的深度,也是一个人技术水准高低比较的表现。

(7)参考文献:

引入参加文献的时候,在引用的句子后面加上序号【1】。参考文献中列出详细来源。不要去抄别人的东西,这是一个基本的态度。

(8)更多讨论:

Q1:提问人:问题?
A1:回答人(可以是分享人,也可以是其他学员):回答
Q2:提问人:问题?
A2:回答人(可以是分享人,也可以是其他学员):回答
Q3:提问人:问题?
A3:回答人(可以是分享人,也可以是其他学员):回答

(9)鸣谢:

感谢XX、XX师兄,此教程是在他们之前技术分享的基础上完善而成。

(10)结束语:

今天的分享就到这里啦,欢迎大家点赞、转发、留言、拍砖~

对Service返回的结果是否要打日志,应该打什么样的日志,为什么?     中品

辅导师兄 [真传弟子]JAVA-童志荣


【修真院Java小课堂】对Service返回的结果是否要打日志,应该打什么样的日志,为什么?

大家好,我是IT修真院北京分院第35期的学员赵君钊,一枚正直纯洁善良的Java程序员,今天给大家分享一下,修真院官网Java(职业)任务二,深度思考中的知识点——对Service返回的结果是否要打日志,应该打什么样的日志,为什么?

1. 背景介绍


在软件开发中,散布于应用中多处的功能被称为横切关注点(cross-cutting concern)。通常来讲,这些横切关注点从概念上是与应用的业务逻辑相分离的。比如:日志、声明式事物、安全和缓存。这些东西都不是我们平时写代码的核心功能,但许多地方都要用到。如果按照面向对象的设计方法来打印日志,我们就必须在要打印日志的类中都加入日志的内容。就是因为面向对象的设计让类与类之间无法联系,而不能将这些重复的代码统一起来。把这些横切关注点与业务相分离正是面向切面编程(AOP)要解决的问题。简单的说就是把这些许多地方都要用到,但又不是核心业务的功能,单独剥离出来封装,通过配置指定要切入到指定的方法中去。


2. 知识剖析


在运行时,动态地将代码切入到类的指定方法、指定位置上,把逻辑代码和处理琐碎事务的代码分离开,以便能够分离复杂度。这种编程思想就是面向切面的编程。横切关注点可以被模块化为特殊的类,这些类被称为切面(aspect)。这样做有两个好处:每个关注点都集中于一个地方,而不是分割到多处代码中。服务模块更简洁,因为它们只包含主要关注点(或核心功能)的代码,而次要关注点的代码被转移到切面中了。


连接点(Join point)


连接点是在应用执行过程中能够插入切面的一个点。这个点可以是调用方法时、抛出异常时、甚至修改一个字段时。切面代码可以利用这些点插入到应用的正常流程之中,并添加行为。


切点(Pointcut )


如果说通知定义了切面“是什么”和“何时”的话,那么切点就定义了“何处”。比如我想把日志引入到某个具体的方法中,这个方法就是所谓的切点。


切面(Aspect)


切面是通知和切点的结合。通知和切点共同定义了切面的全部内容,他是什么,在何时和何处完成其功能。


引入(Introduction)


引入允许我们向现有的类添加新的方法和属性(Spring提供了一个方法注入的功能)


织入(Weaving)


把切面应用到目标对象来创建新的代理对象的过程


通知(Advice)


在AOP中,切面的工作被称为通知。通知定义了切面“是什么”以及“何时”使用。除了描述切面要完成的工作,通知还解决了何时执行这个工作的问题.Spring切面可以应用5种类型的通知

前置通知(Before):在目标方法被调用之前调用通知功能

后置通知(After):在目标方法完成之后调用通知,此时不会关心方法的输出是什么

返回通知(After-returning):在目标方法成功执行之后调用通知

异常通知(After-throwing):在目标方法抛出异常后调用通知

环绕通知(Around):通知包裹了被通知的方法,在被通知的方法调用之前和调用之后执行自定义的行为


3.常见问题


基于注解的方式

基于XML配置的方式


4.解决方案


5.编码实战


6.扩展思考


ProceedingJoinPoint

Around要使用ProceedingJoinPoint这个参数。其中里面的proceed()方法就是将控制权交给被通知的方法。如果你忘记调用这个方法,那么你的通知实际上会阻塞对被通知方法的调用。



SpringMVC的加载问题

在SpringMVC中配置了扫描包的话会先加载所有的Bean,而AOP配置在了Spring的上下文中,SpringMVC加载Serivce的时候AOP还没有配置加载,这时候切面类就会失效


7.参考文献


参考资料:http://tengj.top/2016/05/12/springmvc4aop/

————SpringMVC干货系列:从零搭建SpringMVC+mybatis(四):Spring两大核心之AOP学习


8.更多讨论


Spring AOP and AspectJ AOP 有什么区别?

Spring AOP 基于动态代理方式实现;AspectJ 基于静态代理方式实现。

Spring AOP 仅支持方法级别的 PointCut;提供了完全的 AOP 支持,它还支持属性级别的 PointCut。


AOP 有哪些实现方式?


实现 AOP 的技术,主要分为两大类:

静态代理 - 指使用 AOP 框架提供的命令进行编译,从而在编译阶段就可生成 AOP 代理类,因此也称为编译时增强;

动态代理 - 在运行时在内存中“临时”生成 AOP 动态代理类,因此也被称为运行时增强。


Spring中的代理是什么

将 Advice 应用于目标对象后创建的对象称为代理。在客户端对象的情况下,目标对象和代理对象是相同的。


9.鸣谢


感谢观看,如有出错,恳请指正


10.结束语:


今天的分享就到这里啦,欢迎大家点赞、转发、留言、拍砖~

评论

[北京|荣耀师兄]JAVA-岳晓鹏 发表于 2018-10-02 12:17:18 #1

spirng aop的理解及相关的拓展不错,利用aop和反射的知识跑的demo完成的功能很强大,动态代理这块的知识也了解很深

回复

请您登录 后进行评论