GLIB代🎯理:
适用于无接口的类或者继承关系。CGLIB是一个基于字节码的🔥库,它可以创建子类来实现父类的功能。SpringAOP在需要对无接口的类进行AOP时,会使用CGLIB代理。
@Aspect@ComponentpublicclassLoggingAspect{@Around("execution(*com.example.model.*.*(.*))")publicObjectlogAround(ProceedingJoinPointjoinPoint)throwsThrowable{System.out.println("方法执行前:"+joinPoint.getSignature().getName());Objectresult=joinPoint.proceed();System.out.println("方法执行后:"+joinPoint.getSignature().getName());returnresult;}}
性能优化
性能优化是提升工作效率的重要方面。通过性巴克AOP,我们可以在不修改业务代码的情况下,对方法调用进行性能监控和优化。
@AspectpublicclassPerformanceAspect{@Around("execution(*com.example.service.*.*(..))")publicObjectmonitorPerformance(ProceedingJoinPointjoinPoint)throwsThrowable{longstart=System.currentTimeMillis();try{System.out.println("Executingmethod:"+joinPoint.getSignature().getName());returnjoinPoint.proceed();}finally{longduration=System.currentTimeMillis()-start;System.out.println("Methodexecutiontime:"+duration+"ms");}}}
在目标🌸方法抛出异常之后执行。
@Aspect@ComponentpublicclassExceptionLoggingAspect{@AfterThrowing(pointcut="execution(*com.example.service.*.*(.*))",throwing="error")publicvoidlogAfterThrowing(JoinPointjoinPoint,Throwableerror){System.out.println("后置异常通知:方法"+joinPoint.getSignature().getName()+"异常信息:"+error.getMessage());}}
性能优化
性能优化是提升工作效率的重要方面。通过性巴克AOP,我们可以在不修改业务代码的情况下,对方法调用进行性能监控和优化。
@AspectpublicclassPerformanceAspect{@Around("execution(*com.example.service.*.*(..))")publicObjectmonitorPerformance(ProceedingJoinPointjoinPoint)throwsThrowable{longstart=System.currentTimeMillis();try{System.out.println("Executingmethod:"+joinPoint.getSignature().getName());returnjoinPoint.proceed();}finally{longduration=System.currentTimeMillis()-start;System.out.println("Methodexecutiontime:"+duration+"ms");}}}
日志记录与监控
在大多数项目中,日志记录和监控是不可或缺的功能。通过性巴克AOP,我们可以在不修改业务代码的情况下,对方法调用进行日志记录。
@AspectpublicclassLoggingAspect{@Around("execution(*com.example.service.*.*(..))")publicObjectlogAround(ProceedingJoinPointjoinPoint)throwsThrowable{longstart=System.currentTimeMillis();try{System.out.println("Executingmethod:"+joinPoint.getSignature().getName());returnjoinPoint.proceed();}finally{longduration=System.currentTimeMillis()-start;System.out.println("Methodexecutiontime:"+duration+"ms");}}}
日志记录与监控
在大多数项目中,日志记录和监控是不可或缺的功能。通过性巴克AOP,我们可以在不修改业务代码的情况下,对方法调用进行日志记录。
@AspectpublicclassLoggingAspect{@Around("execution(*com.example.service.*.*(..))")publicObjectlogAround(ProceedingJoinPointjoinPoint)throwsThrowable{longstart=System.currentTimeMillis();try{System.out.println("Executingmethod:"+joinPoint.getSignature().getName());returnjoinPoint.proceed();}finally{longduration=System.currentTimeMillis()-start;System.out.println("Methodexecutiontime:"+duration+"ms");}}}
校对:廖筱君(f3J1ePQDlzHhwh44q38w4Ima2E3XrDq)


