????????
? ? ? ? 当需要为多个不具有继承关系的对象引入一个公共的行为,例如:日志、安全检测等,起初我们只有在每个对象里面引用这些公共的行为,但是这样做会导致程序出现大量的重复代码,不便于维护。?
????????前言中,引用了书上的一段话,读完之后,脑子里产生了一个问题,对于出现大量的重复代码,不便于维护的问题,我们也可以写一个公共方法,来给对象调用就行了,那么为什么还要使用切面呢?
? ? ? ? 要解释这个问题,首先需要知道切面的关注点在哪里:切面所关注方向是横向的,而传统OOP是纵向的。怎么理解这段话?
????????
? ? ? ?看下这张图,1-2-3-4这个步骤,是程序的业务代码,一步一步的向下执行;而A-B-C这个步骤,就是切面的逻辑,它和业务代码是分开的,不会影响业务代码的执行;如果使用引入公共方法的方式,那么必然会将其直接添加到业务代码中,这就使得业务代码和非业务代码耦合了。因此,总结下切面的优点:
import java.lang.annotation.*;
@Target({ElementType.METHOD})
@Retention(RetentionPolicy.RUNTIME)
@Documented
public @interface Log {
//参数类
Class< ? extends ConvertParam> convert();
//操作类型
BusinessType businessType() default BusinessType.OTHER;
}
@Aspect
@Component
public class LogAspect {
@Resource
HttpServletRequest httpServletRequest;
/**
* 定义切面
*/
@Pointcut("@annotation(com.cart.cartservice.Log.annotation.Log)")
public void section() {
}
/**
* 环绕切点
*
* @param
* @return result
*/
@Around("section()")
public Object log(ProceedingJoinPoint joinPoint) throws Throwable {
//注解修饰的方法的返回结果
Object result = joinPoint.proceed();
//切面逻辑,收集日志什么的
handleLog(joinPoint, result);
//这个别忘记了
return result;
}
@SneakyThrows
private void handleLog(ProceedingJoinPoint joinPoint, Object result) {
//标准三部曲,拿取注解
MethodSignature signature = (MethodSignature) joinPoint.getSignature();
Method method = signature.getMethod();
Log logAnnotation = method.getAnnotation(Log.class);
//获取方法参数
Object[] args = joinPoint.getArgs();
//实现切面的逻辑。例如:收集日志等
}
}
@Log(convert = IntegerConvertParamImpl.class,businessType = BusinessType.QUERY)
@GetMapping("{id}")
public ResponseEntity<Cart> queryById(@PathVariable("id") Integer id) {
return ResponseEntity.ok(this.cartService.queryById(id));
}
提示:这里对文章进行总结:
例如:以上就是今天要讲的内容,本文仅仅简单介绍了pandas的使用,而pandas提供了大量能使我们快速便捷地处理数据的函数和方法。