R
- 这个访问者方法的返回类型。
对不需要返回结果的访问者使用Void
。
P
- 访问者方法的附加参数类型。
对不需要Void
的访问者使用Void。
public interface TypeVisitor<R,P>
accept
方法时,调用最适用于该类型的visitXYZ方法。
实现此界面的类可以或可以不抛出NullPointerException
如果附加参数p
是null
; 有关详细信息,请参阅实施类的文档。
警告:可能的方法将添加到此界面以适应未来版本的Java编程语言中添加的新的,当前未知的语言结构。 因此,直接实现此接口的访问者类可能与未来的平台版本不兼容。 为了避免这种源不兼容,我们鼓励访问者实现扩展实现此接口的适当抽象访问类。 然而,API通常应该将此访问接口用作参数,返回类型等的类型,而不是抽象类之一。
请注意,如果添加为默认方法,则可以以源兼容的方式添加适应新语言结构的方法 。 但是,默认方法仅适用于Java SE 8和更高版本,并且Java SE 8中捆绑的javax.lang.model.*
软件包也需要在Java SE 7上运行。因此,在扩展javax.lang.model.*
以涵盖Java SE 8语言时,不能使用默认方法特征。 但是,默认方法可能会用于仅在Java SE 8和更高版本平台上运行的javax.lang.model.*
软件包的javax.lang.model.*
版本。
Modifier and Type | Method and Description |
---|---|
R |
visit(TypeMirror t)
方便方法相当于
v.visit(t, null) 。
|
R |
visit(TypeMirror t, P p)
访问类型。
|
R |
visitArray(ArrayType t, P p)
访问数组类型。
|
R |
visitDeclared(DeclaredType t, P p)
访问已声明的类型。
|
R |
visitError(ErrorType t, P p)
访问错误类型。
|
R |
visitExecutable(ExecutableType t, P p)
访问可执行文件类型。
|
R |
visitIntersection(IntersectionType t, P p)
访问交叉路口类型。
|
R |
visitNoType(NoType t, P p)
访问一个 NoType 实例。
|
R |
visitNull(NullType t, P p)
访问空类型。
|
R |
visitPrimitive(PrimitiveType t, P p)
访问原始类型。
|
R |
visitTypeVariable(TypeVariable t, P p)
访问类型变量。
|
R |
visitUnion(UnionType t, P p)
访问联合类型。
|
R |
visitUnknown(TypeMirror t, P p)
访问未知类型的类型。
|
R |
visitWildcard(WildcardType t, P p)
访问通配符类型。
|
R visit(TypeMirror t, P p)
t
- 要访问的类型
p
- 访客指定的参数
R visit(TypeMirror t)
v.visit(t, null)
。
t
- 要访问的元素
R visitPrimitive(PrimitiveType t, P p)
t
- 要访问的类型
p
- 访客指定的参数
R visitDeclared(DeclaredType t, P p)
t
- 要访问的类型
p
- 访客指定的参数
R visitTypeVariable(TypeVariable t, P p)
t
- 要访问的类型
p
- 访客指定的参数
R visitWildcard(WildcardType t, P p)
t
- 要访问的类型
p
- 访客指定的参数
R visitExecutable(ExecutableType t, P p)
t
- 要访问的类型
p
- 访客指定的参数
R visitUnknown(TypeMirror t, P p)
TypeMirror
层次结构中,则可能会发生这种情况。
t
- 要访问的类型
p
- 访客指定的参数
UnknownTypeException
- 访客实现可以可选地抛出此异常
R visitIntersection(IntersectionType t, P p)
t
- 要访问的类型
p
- 访客指定的参数
Submit a bug or feature
For further API reference and developer documentation, see Java SE Documentation. That documentation contains more detailed, developer-targeted descriptions, with conceptual overviews, definitions of terms, workarounds, and working code examples.
Copyright © 1993, 2014, Oracle and/or its affiliates. All rights reserved.