类 AspectJExpressionPointcut
java.lang.Object
cn.taketoday.aop.support.AbstractExpressionPointcut
cn.taketoday.aop.aspectj.AspectJExpressionPointcut
- 所有已实现的接口:
ClassFilter,IntroductionAwareMethodMatcher,MethodMatcher,Pointcut,ExpressionPointcut,Aware,BeanFactoryAware,Serializable
public class AspectJExpressionPointcut
extends AbstractExpressionPointcut
implements ClassFilter, IntroductionAwareMethodMatcher, BeanFactoryAware
Framework
Pointcut implementation
that uses the AspectJ weaver to evaluate a pointcut expression.
The pointcut expression value is an AspectJ expression. This can reference other pointcuts and use composition and other operations.
Naturally, as this is to be processed by Framework AOP's proxy-based model, only method execution pointcuts are supported.
- 从以下版本开始:
- 4.0
- 作者:
- Rob Harrop, Adrian Colyer, Rod Johnson, Juergen Hoeller, Ramnivas Laddad, Dave Syer, Harry Yang
- 另请参阅:
-
字段概要
从接口继承的字段 cn.taketoday.aop.ClassFilter
TRUE从接口继承的字段 cn.taketoday.aop.MethodMatcher
TRUE -
构造器概要
构造器构造器说明Create a new default AspectJExpressionPointcut.AspectJExpressionPointcut(Class<?> declarationScope, String[] paramNames, Class<?>[] paramTypes) Create a new AspectJExpressionPointcut with the given settings. -
方法概要
修饰符和类型方法说明booleanReturn the ClassFilter for this pointcut.protected StringReturn the MethodMatcher for this pointcut.org.aspectj.weaver.tools.PointcutExpressionReturn the underlying AspectJ pointcut expression.inthashCode()booleanIs this MethodMatcher dynamic, that is, must a final call be made on theMethodMatcher.matches(MethodInvocation)method at runtime even if the 2-arg matches method returnstrue?booleanShould the pointcut apply to the given interface or target class?booleanChecking whether the given method matches.booleanPerform static checking whether the given method matches.booleanmatches(MethodInvocation invocation) Check whether there a runtime (dynamic) match for this method, which must have matched statically.voidsetBeanFactory(BeanFactory beanFactory) voidsetParameterNames(String... names) Set the parameter names for the pointcut.voidsetParameterTypes(Class<?>... types) Set the parameter types for the pointcut.voidsetPointcutDeclarationScope(Class<?> pointcutDeclarationScope) Set the declaration scope for the pointcut.toString()从类继承的方法 cn.taketoday.aop.support.AbstractExpressionPointcut
getExpression, getLocation, onSetExpression, setExpression, setLocation
-
构造器详细资料
-
AspectJExpressionPointcut
public AspectJExpressionPointcut()Create a new default AspectJExpressionPointcut. -
AspectJExpressionPointcut
public AspectJExpressionPointcut(@Nullable Class<?> declarationScope, String[] paramNames, Class<?>[] paramTypes) Create a new AspectJExpressionPointcut with the given settings.- 参数:
declarationScope- the declaration scope for the pointcutparamNames- the parameter names for the pointcutparamTypes- the parameter types for the pointcut
-
-
方法详细资料
-
setPointcutDeclarationScope
Set the declaration scope for the pointcut. -
setParameterNames
Set the parameter names for the pointcut. -
setParameterTypes
Set the parameter types for the pointcut. -
setBeanFactory
- 指定者:
setBeanFactory在接口中BeanFactoryAware
-
getClassFilter
从接口复制的说明:PointcutReturn the ClassFilter for this pointcut.- 指定者:
getClassFilter在接口中Pointcut- 返回:
- the ClassFilter (never
null)
-
getMethodMatcher
从接口复制的说明:PointcutReturn the MethodMatcher for this pointcut.- 指定者:
getMethodMatcher在接口中Pointcut- 返回:
- the MethodMatcher (never
null)
-
getPointcutExpression
public org.aspectj.weaver.tools.PointcutExpression getPointcutExpression()Return the underlying AspectJ pointcut expression. -
matches
从接口复制的说明:ClassFilterShould the pointcut apply to the given interface or target class?- 指定者:
matches在接口中ClassFilter- 参数:
targetClass- the candidate target class- 返回:
- whether the advice should apply to the given target class
-
matches
从接口复制的说明:IntroductionAwareMethodMatcherPerform static checking whether the given method matches. This may be invoked instead of the 2-argMethodMatcher.matches(java.lang.reflect.Method, Class)method if the caller supports the extended IntroductionAwareMethodMatcher interface.- 指定者:
matches在接口中IntroductionAwareMethodMatcher- 参数:
method- the candidate methodtargetClass- the target classhasIntroductions-trueif the object on whose behalf we are asking is the subject on one or more introductions;falseotherwise- 返回:
- whether or not this method matches statically
-
matches
从接口复制的说明:MethodMatcherChecking whether the given method matches.- 指定者:
matches在接口中MethodMatcher- 参数:
method- the candidate methodtargetClass- the target class- 返回:
- whether or not this method matches on application startup.
-
isRuntime
public boolean isRuntime()从接口复制的说明:MethodMatcherIs this MethodMatcher dynamic, that is, must a final call be made on theMethodMatcher.matches(MethodInvocation)method at runtime even if the 2-arg matches method returnstrue?Can be invoked when an AOP proxy is created, and need not be invoked again before each method invocation,
- 指定者:
isRuntime在接口中MethodMatcher- 返回:
- whether or not a runtime match via the 1-arg
MethodMatcher.matches(MethodInvocation)method is required if static matching passed
-
matches
从接口复制的说明:MethodMatcherCheck whether there a runtime (dynamic) match for this method, which must have matched statically.This method is invoked only if the 2-arg matches method returns
truefor the given method and target class, and if theMethodMatcher.isRuntime()method returnstrue. Invoked immediately before potential running of the advice, after any advice earlier in the advice chain has run.- 指定者:
matches在接口中MethodMatcher- 参数:
invocation- runtime invocation contains the candidate method and target class, arguments to the method- 返回:
- whether there's a runtime match
- 另请参阅:
-
getCurrentProxiedBeanName
-
equals
-
hashCode
public int hashCode() -
toString
-