java.lang.Object java.lang.reflect.AccessibleObject java.lang.reflect.Field
public final class Field
Field
提供有关类或接口的单个字段的信息,以及对它的动态访问权限。反射的字段可能是一个类(静态)字段或实例字段。
Array
允许在执行 get 或 set 访问操作期间进行扩展转换,但如果将发生收缩转换,则抛出一个 IllegalArgumentException
。
Member
,
Class
,
Class.getFields()
,
Class.getField(String)
,
Class.getDeclaredFields()
,
Class.getDeclaredField(String)
字段摘要 |
---|
从接口 java.lang.reflect.Member 继承的字段 |
---|
DECLARED, PUBLIC |
方法摘要 | ||
---|---|---|
boolean |
equals(Object obj) 将此 Field 与指定对象比较。 |
|
Object |
get(Object obj) 返回指定对象上此 Field 表示的字段的值。 |
|
|
getAnnotation(Class<T> annotationClass) 如果存在该元素的指定类型的注释,则返回这些注释,否则返回 null。 |
|
boolean |
getBoolean(Object obj) 获取一个静态或实例 boolean 字段的值。 |
|
byte |
getByte(Object obj) 获取一个静态或实例 byte 字段的值。 |
|
char |
getChar(Object obj) 获取 char 类型或另一个通过扩展转换可以转换为 char 类型的基本类型的静态或实例字段的值。 |
|
Annotation[] |
getDeclaredAnnotations() 返回直接存在于此元素上的所有注释。 |
|
Class<?> |
getDeclaringClass() 返回表示类或接口的 Class 对象,该类或接口声明由此 Field 对象表示的字段。 |
|
double |
getDouble(Object obj) 获取 double 类型或另一个通过扩展转换可以转换为 double 类型的基本类型的静态或实例字段的值。 |
|
float |
getFloat(Object obj) 获取 float 类型或另一个通过扩展转换可以转换为 float 类型的基本类型的静态或实例字段的值。 |
|
Type |
getGenericType() 返回一个 Type 对象,它表示此 Field 对象所表示字段的声明类型。 |
|
int |
getInt(Object obj) 获取 int 类型或另一个通过扩展转换可以转换为 int 类型的基本类型的静态或实例字段的值。 |
|
long |
getLong(Object obj) 获取 long 类型或另一个通过扩展转换可以转换为 long 类型的基本类型的静态或实例字段的值。 |
|
int |
getModifiers() 以整数形式返回由此 Field 对象表示的字段的 Java 语言修饰符。 |
|
String |
getName() 返回此 Field 对象表示的字段的名称。 |
|
short |
getShort(Object obj) 获取 short 类型或另一个通过扩展转换可以转换为 short 类型的基本类型的静态或实例字段的值。 |
|
Class<?> |
getType() 返回一个 Class 对象,它标识了此 Field 对象所表示字段的声明类型。 |
|
int |
hashCode() 返回该 Field 的哈希码。 |
|
boolean |
isEnumConstant() 如果此字段表示枚举类型的元素,则返回 true;否则返回 false。 |
|
boolean |
isSynthetic() 如果此字段是复合字段,则返回 true;否则返回 false。 |
|
void |
set(Object obj, Object value) 将指定对象变量上此 Field 对象表示的字段设置为指定的新值。 |
|
void |
setBoolean(Object obj, boolean z) 将字段的值设置为指定对象上的一个 boolean 值。 |
|
void |
setByte(Object obj, byte b) 将字段的值设置为指定对象上的一个 byte 值。 |
|
void |
setChar(Object obj, char c) 将字段的值设置为指定对象上的一个 char 值。 |
|
void |
setDouble(Object obj, double d) 将字段的值设置为指定对象上的一个 double 值。 |
|
void |
setFloat(Object obj, float f) 将字段的值设置为指定对象上的一个 float 值。 |
|
void |
setInt(Object obj, int i) 将字段的值设置为指定对象上的一个 int 值。 |
|
void |
setLong(Object obj, long l) 将字段的值设置为指定对象上的一个 long 值。 |
|
void |
setShort(Object obj, short s) 将字段的值设置为指定对象上的一个 short 值。 |
|
String |
toGenericString() 返回一个描述此 Field (包括其一般类型)的字符串。 |
|
String |
toString() 返回一个描述此 Field 的字符串。 |
从类 java.lang.reflect.AccessibleObject 继承的方法 |
---|
getAnnotations, isAccessible, isAnnotationPresent, setAccessible, setAccessible |
从类 java.lang.Object 继承的方法 |
---|
clone, finalize, getClass, notify, notifyAll, wait, wait, wait |
方法详细信息 |
---|
public Class<?> getDeclaringClass()
Class
对象,该类或接口声明由此
Field
对象表示的字段。
Member
中的
getDeclaringClass
public String getName()
public int getModifiers()
Field
对象表示的字段的 Java 语言修饰符。应该使用
Modifier
类对这些修饰符进行解码。
Member
中的
getModifiers
Modifier
public boolean isEnumConstant()
public boolean isSynthetic()
Member
中的
isSynthetic
public Class<?> getType()
Class
对象,它标识了此
Field
对象所表示字段的声明类型。
Class
对象
public Type getGenericType()
如果 Type 是一个参数化类型,则返回的 Type 对象必须准确地反映源代码中使用的实际类型参数。
如果底层字段的类型是一个类型变量或者是一个参数化类型,则创建它。否则将解析它。
Field
对象所表示字段的声明类型的
Type 对象
GenericSignatureFormatError
- 如果一般字段签名不符合 Java Virtual Machine Specification, 3rd edition 中指定的格式
TypeNotPresentException
- 如果底层字段的一般类型签名引用了不存在的类型声明
MalformedParameterizedTypeException
- 如果底层字段的一般签名引用了一个因某种原因而无法实例化的参数化类型
public boolean equals(Object obj)
Field
与指定对象比较。如果对象是相同的,则返回 true。如果由相同的类声明并且具有相同的名称和类型,那么这两个
Field
对象是相同的。
obj
- 要与之比较的引用对象。
true
;否则返回
false
。
Object.hashCode()
,
Hashtable
public int hashCode()
Field
的哈希码。这作为底层字段的声明类名及其名称的哈希码的异或进行计算。
Object.equals(java.lang.Object)
,
Hashtable
public String toString()
Field
的字符串。格式是:该字段(如果存在的话)的访问修饰符,后面跟着字段类型和一个空格,再后面是声明该字段的类的完全限定名,后面跟着一个句点,最后是字段的名称。例如:
public static final int java.lang.Thread.MIN_PRIORITY private int java.io.FileDescriptor.fd
修饰符是按照 "The Java Language Specification" 中指定的规范化顺序放置的。public、protected 或 private 的修饰符放在最前面,然后按以下顺序放置其他修饰符:static、final、transient 和 volatile。
public String toGenericString()
Field
(包括其一般类型)的字符串。格式是:该字段(如果存在的话)的访问修饰符,后面跟着一般字段类型和一个空格,再后面是声明该字段的类的完全限定名,后面跟着一个句点,最后是字段的名称。
修饰符是按照 "The Java Language Specification" 中指定的规范化顺序放置的。public、protected 或 private 的修饰符放在最前面,然后按以下顺序放置其他修饰符:static、final、transient 和 volatile。
Field
(包括其一般类型)的字符串
public Object get(Object obj) throws IllegalArgumentException, IllegalAccessException
Field
表示的字段的值。如果该值是一个基本类型值,则自动将其包装在一个对象中。
底层字段的值是按以下方式获得的:
如果底层字段是一个静态字段,则忽略 obj
变量;它可能为 null。
否则,底层字段是一个实例字段。如果指定的 obj
变量为 null,则该方法将抛出一个 NullPointerException
。如果指定对象不是声明底层字段的类或接口的实例,则该方法将抛出一个 IllegalArgumentException
。
如果此 Field
对象强制实施 Java 语言访问控制,并且底层字段是不可访问的,则该方法将抛出一个 IllegalAccessException
。如果底层字段是静态的,并且声明该字段的类尚未初始化,则初始化这个类。
否则,从底层实例字段或静态字段中获取该值。如果该字段是一个基本类型字段,则在返回前将该值包装在一个对象中,否则照原样返回。
如果字段隐藏在 obj
的类型中,则根据前面的规则获得字段的值。
obj
- 从中提取所表示字段的值的对象
IllegalAccessException
- 如果底层字段是不可访问的。
IllegalArgumentException
- 如果指定对象不是声明底层字段(或者其子类或实现者)的类或接口的实例。
NullPointerException
- 如果指定对象为 null 并且字段是一个实例字段。
ExceptionInInitializerError
- 如果此方法引起的初始化失败。
public boolean getBoolean(Object obj) throws IllegalArgumentException, IllegalAccessException
boolean
字段的值。
obj
- 从中提取
boolean
值的对象
boolean
字段的值
IllegalAccessException
- 如果底层字段是不可访问的。
IllegalArgumentException
- 如果指定对象不是声明底层字段(或者其子类或实现者)的类或接口的实例,或者无法通过扩展转换将字段值转换为
boolean
类型。
NullPointerException
- 如果指定对象为 null 并且字段是一个实例字段。
ExceptionInInitializerError
- 如果此方法引起的初始化失败。
get(java.lang.Object)
public byte getByte(Object obj) throws IllegalArgumentException, IllegalAccessException
byte
字段的值。
obj
- 从中提取
byte
值的对象
byte
字段的值
IllegalAccessException
- 如果底层字段是不可访问的。
IllegalArgumentException
- 如果指定对象不是声明底层字段(或者其子类或实现者)的类或接口的实例,或者无法通过扩展转换将字段值转换为
byte
类型。
NullPointerException
- 如果指定对象为 null 并且字段是一个实例字段。
ExceptionInInitializerError
- 如果此方法引起的初始化失败。
get(java.lang.Object)
public char getChar(Object obj) throws IllegalArgumentException, IllegalAccessException
char
类型或另一个通过扩展转换可以转换为
char
类型的基本类型的静态或实例字段的值。
obj
- 从中提取
char
值的对象
char
类型的字段的值
IllegalAccessException
- 如果底层字段是不可访问的。
IllegalArgumentException
- 如果指定对象不是声明底层字段(或者其子类或实现者)的类或接口的实例,或者无法通过扩展转换将字段值转换为
char
类型。
NullPointerException
- 如果指定对象为 null 并且字段是一个实例字段。
ExceptionInInitializerError
- 如果此方法引起的初始化失败。
get(java.lang.Object)
public short getShort(Object obj) throws IllegalArgumentException, IllegalAccessException
short
类型或另一个通过扩展转换可以转换为
short
类型的基本类型的静态或实例字段的值。
obj
- 从中提取
short
值的对象
short
类型的字段的值
IllegalAccessException
- 如果底层字段是不可访问的。
IllegalArgumentException
- 如果指定对象不是声明底层字段(或者其子类或实现者)的类或接口的实例,或者无法通过扩展转换将字段值转换为
short
类型。
NullPointerException
- 如果指定对象为 null 并且字段是一个实例字段。
ExceptionInInitializerError
- 如果此方法引起的初始化失败。
get(java.lang.Object)
public int getInt(Object obj) throws IllegalArgumentException, IllegalAccessException
int
类型或另一个通过扩展转换可以转换为
int
类型的基本类型的静态或实例字段的值。
obj
- 从中提取
int
值的对象
int
类型的字段的值
IllegalAccessException
- 如果底层字段是不可访问的。
IllegalArgumentException
- 如果指定对象不是声明底层字段(或者其子类或实现者)的类或接口的实例,或者无法通过扩展转换将字段值转换为
int
类型。
NullPointerException
- 如果指定对象为 null 并且字段是一个实例字段。
ExceptionInInitializerError
- 如果此方法引起的初始化失败。
get(java.lang.Object)
public long getLong(Object obj) throws IllegalArgumentException, IllegalAccessException
long
类型或另一个通过扩展转换可以转换为
long
类型的基本类型的静态或实例字段的值。
obj
- 从中提取
long
值的对象
long
类型的字段的值
IllegalAccessException
- 如果底层字段是不可访问的。
IllegalArgumentException
- 如果指定对象不是声明底层字段(或者其子类或实现者)的类或接口的实例,或者无法通过扩展转换将字段值转换为
long
类型。
NullPointerException
- 如果指定对象为 null 并且字段是一个实例字段。
ExceptionInInitializerError
- 如果此方法引起的初始化失败。
get(java.lang.Object)
public float getFloat(Object obj) throws IllegalArgumentException, IllegalAccessException
float
类型或另一个通过扩展转换可以转换为
float
类型的基本类型的静态或实例字段的值。
obj
- 从中提取
float
值的对象
float
类型的字段的值
IllegalAccessException
- 如果底层字段是不可访问的。
IllegalArgumentException
- 如果指定对象不是声明底层字段(或者其子类或实现者)的类或接口的实例,或者无法通过扩展转换将字段值转换为
float
类型。
NullPointerException
- 如果指定对象为 null 并且字段是一个实例字段。
ExceptionInInitializerError
- 如果此方法引起的初始化失败。
get(java.lang.Object)
public double getDouble(Object obj) throws IllegalArgumentException, IllegalAccessException
double
类型或另一个通过扩展转换可以转换为
double
类型的基本类型的静态或实例字段的值。
obj
- 从中提取
double
值的对象
double
类型的字段的值
IllegalAccessException
- 如果底层字段是不可访问的。
IllegalArgumentException
- 如果指定对象不是声明底层字段(或者其子类或实现者)的类或接口的实例,或者无法通过扩展转换将字段值转换为
double
类型。
NullPointerException
- 如果指定对象为 null 并且字段是一个实例字段。
ExceptionInInitializerError
- 如果此方法引起的初始化失败。
get(java.lang.Object)
public void set(Object obj, Object value) throws IllegalArgumentException, IllegalAccessException
Field
对象表示的字段设置为指定的新值。如果底层字段的类型为基本类型,则对新值进行自动解包。
进行此操作的方式如下:
如果底层字段是静态字段,则忽略 obj
变量;它可能为 null。
否则底层字段是一个实例字段。如果指定对象变量为 null,则该方法将抛出一个 NullPointerException
。如果指定对象变量不是声明底层字段的类或接口的实例,则该方法将抛出一个 IllegalArgumentException
。
如果此 Field
对象实施 Java 语言访问控制,并且底层字段是不可访问的,则该方法将抛出一个 IllegalAccessException
。
如果底层字段为 final 字段,则该方法将抛出一个 IllegalAccessException
,除非 setAccessible(true)
已经继承该字段并且该字段是一个非静态字段。在通过程序的其他部分可以访问类的实例之前,只有使用空白 final 字段反序列化或重构类的实例期间,以这种方式设置 final 字段才有意义。在其他任何上下文中使用该方法都可能会有不可预知的结果,包括程序的其他部分继续使用该字段的原始值的情况。
如果底层字段的类型为某一基本类型,则可以尝试使用解包转换将新值转换为基本类型的值。如果该尝试失败,则此方法将抛出一个 IllegalArgumentException
。
如果在进行可能的解包之后,无法通过某一标识或扩展转换将新值转换为底层字段的类型,则此方法将抛出一个 IllegalArgumentException
。
如果底层字段是静态的,并且声明该字段的类尚未初始化,则初始化这个类。
字段被设置为可能已解包并扩大的新值。
如果字段隐藏在 obj
的类型中,则根据前面的规则设置字段的值。
obj
- 应该修改其字段的对象
value
- 正被修改的
obj
的字段的新值
IllegalAccessException
- 如果底层字段是不可访问的。
IllegalArgumentException
- 如果指定对象不是声明底层字段(或者其子类或实现者)的类或接口的实例,或者解包转换失败。
NullPointerException
- 如果指定对象为 null 并且字段是一个实例字段。
ExceptionInInitializerError
- 如果此方法引起的初始化失败。
public void setBoolean(Object obj, boolean z) throws IllegalArgumentException, IllegalAccessException
boolean
值。该方法等同于
set(obj, zObj)
,其中
zObj
是一个
Boolean
对象,并且
zObj.booleanValue() == z
。
obj
- 应该修改其字段的对象
z
- 正被修改的
obj
的字段的新值
IllegalAccessException
- 如果底层字段是不可访问的。
IllegalArgumentException
- 如果指定对象不是声明底层字段(或者其子类或实现者)的类或接口的实例,或者解包转换失败。
NullPointerException
- 如果指定对象为 null 并且字段是一个实例字段。
ExceptionInInitializerError
- 如果此方法引起的初始化失败。
set(java.lang.Object, java.lang.Object)
public void setByte(Object obj, byte b) throws IllegalArgumentException, IllegalAccessException
byte
值。该方法等同于
set(obj, bObj)
,其中
bObj
是一个
Byte
对象,并且
bObj.byteValue() == b
。
obj
- 应该修改其字段的对象
b
- 正被修改的
obj
的字段的新值
IllegalAccessException
- 如果底层字段是不可访问的。
IllegalArgumentException
- 如果指定对象不是声明底层字段(或者其子类或实现者)的类或接口的实例,或者解包转换失败。
NullPointerException
- 如果指定对象为 null 并且字段是一个实例字段。
ExceptionInInitializerError
- 如果此方法引起的初始化失败。
set(java.lang.Object, java.lang.Object)
public void setChar(Object obj, char c) throws IllegalArgumentException, IllegalAccessException
char
值。该方法等同于
set(obj, cObj)
,其中
cObj
是一个
Character
对象,并且
cObj.charValue() == c
。
obj
- 应该修改其字段的对象