Java Field 详解

一.主要方法

getType(): 获取属性声明时类型对象(返回class对象)

getGenericType() : 返回属性声的Type类型

getName() : 获取属性声明时名字

getAnnotations() : 获得这个属性上所有的注释

getModifiers() : 获取属性的修饰

isEnumConstant() : 判断这个属性是否是枚举类

isSynthetic() : 判断这个属性是否是 复合类

get(Object obj) : 取得obj对象这个Field上的值

set(Object obj, Object value) : 向obj对象的这个Field设置新值value

Field类中最常用的是get(Object obj)和set(Object obj, Object value)这两个方法,所以这两个方法是最重要的。

getType() 和 getGenericType()的区别 :

1.首先是返回的类型不一样,一个是Class对象一个是Type接口

2.如果属性是一个泛型,从getType()只能得到这个属性的接口类型。但从getGenericType()还能得到这个泛型的参数类型。

isEnumConstant()isSynthetic() :

对象中如果有属性是枚举类或复合类,用这两个方法返回的值并不是我们想象的true而是false。其实这两个方法是对编译生成的才有效。

二.试验代码

<span style="font-family:Microsoft YaHei;">package test.fortest;
 
import static java.lang.System.out;
 
import java.lang.reflect.Field;
 
import javassist.Modifier;
import test.model.Role;
 
public class FieldTest {
    enum Color {
        Blue,
        Red
    }
     
    class Inner {
    }
     
    public static void main(String args[]) {
        Role role = new Role();
        role.setId("role1");
        role.setUserId("user1");
        role.setRoleName("Role 1");
         
        Field idField =  getDeclaredField(role.getClass(), "id");
        Field childrenField =  getDeclaredField(role.getClass(), "children");
        Field roleTypeField =  getDeclaredField(role.getClass(), "roleType");
        Field userField =  getDeclaredField(role.getClass(), "user");
         
        //获取属性声明时类型对象(返回class对象)
        System.out.println(idField.getType());
        //返回属性声的Type类型
        System.out.println(idField.getGenericType());
        //如果属性是一个泛型,从getType只能得到这个属性的接口类型
        System.out.println(childrenField.getType());
        //如果属性是一个参数化类型,从getGenericType还能得到这个泛型的参数类型
        System.out.println(childrenField.getGenericType());
        //获取属性声明时名字
        System.out.println(idField.getName());
        //获得这个属性上所有的注释
        System.out.println(idField.getAnnotations().length);
        //获取属性的修饰
        System.out.println(Modifier.toString(idField.getModifiers()));
         
        //判断这个属性是否是枚举类
        System.out.println(roleTypeField.isEnumConstant());
        //判断这个属性是否是 复合类
        System.out.println(userField.isSynthetic());
        //FieldTest$Color是Color枚举类编译后的名字。
        isSyntheticOrEnumConstant("test.fortest.FieldTest$Color");
        //FieldTest$Inner是Inner类编译后的名字。
        isSyntheticOrEnumConstant("test.fortest.FieldTest$Inner");
        try {
            //取得对象这个Field上的值
            System.out.println(idField.get(role));
            //向对象的这个Field重新设置值
            idField.set(role, "role2");
            System.out.println(idField.get(role));
        } catch (IllegalArgumentException e) {
            e.printStackTrace();
        } catch (IllegalAccessException e) {
            e.printStackTrace();
        }
         
    }
     
    public static Field getDeclaredField(final Class cla, final String fieldName) {
        for (Class superClass = cla; superClass != null; superClass = superClass.getSuperclass()) {
            try {
                return superClass.getDeclaredField(fieldName);
            } catch (NoSuchFieldException e) {
//              e.printStackTrace();
            }
        }
        return null;
    }
     
    public static void isSyntheticOrEnumConstant (String completePackageName) {
        try {
            Class<?> c = Class.forName(completePackageName);
            Field[] flds = c.getDeclaredFields(); 
            for (Field f : flds) {  
                out.format("%-8s [ synthetic=%-5b enum_constant=%-5b ]%n",
                        c.getName() + ":" + f.getName(), f.isSynthetic(), f.isEnumConstant());  
            }  
        } catch (ClassNotFoundException e) {
            e.printStackTrace();
        } 
    }
}</span>


结果:

<span style="font-family:Microsoft YaHei;">class java.lang.String
class java.lang.String
interface java.util.List
java.util.List<test.model.User>
id
5
public
false
false
test.fortest.FieldTest$Color:Blue [ synthetic=false enum_constant=true  ]
test.fortest.FieldTest$Color:Red [ synthetic=false enum_constant=true  ]
test.fortest.FieldTest$Color:ENUM$VALUES [ synthetic=true  enum_constant=false ]
test.fortest.FieldTest$Inner:this$0 [ synthetic=true  enum_constant=false ]
role1
role2</span>


三.用到的类

<span style="font-family:Microsoft YaHei;">package test.model;
 
import java.util.List;
 
import javax.persistence.Entity;
import javax.persistence.Table;
 
import test.enu.RoleType;
 
@Entity
@Table(schema = "public")
public class Role extends AbsEntity implements IEntity{
    public String roleName;
     
    public String userId;
 
    public List<User> children;
     
    private RoleType roleType = RoleType.Manager;
     
    private User user;
     
    public Role() {}
     
    private Role(String roleName) {
        this.roleName = roleName;
    }
    public String getRoleName() {
        return roleName;
    }
 
    public void setRoleName(String roleName) {
        this.roleName = roleName;
    }
 
    public String getUserId() {
        return userId;
    }
 
    public void setUserId(String userId) {
        this.userId = userId;
    }
 
    public String getDisplayString() {
        System.out.println("I am a Role");
        return "Role";
    }
     
}</span>

<span style="font-family:Microsoft YaHei;">packagetest.enu;
 
publicenum RoleType{
    Manager,Employee;
}</span>

<span style="font-family:Microsoft YaHei;">packagetest.model;
 
importjavax.persistence.Column;
importjavax.persistence.Entity;
importjavax.persistence.GeneratedValue;
importjavax.persistence.Id;
importjavax.persistence.ManyToOne;
importjavax.persistence.Table;
 
importorg.hibernate.annotations.AccessType;
importorg.hibernate.annotations.GenericGenerator;
 
@Entity
@Table(name = "users", schema = "public")
publicclass User {
    @Id
    @GeneratedValue(generator = "system-uuid")
    @GenericGenerator(name = "system-uuid", strategy = "uuid.hex")
    @Column(length = 40)
    @AccessType("property")
    privateString id;
     
    privateString loginName;
     
    privateString password;
     
    privateString address;
     
    @ManyToOne
    privateRole role;
 
    publicString getId() {
        returnid;
    }
 
    protectedvoid setId(String id) {
        this.id = id;
    }
 
    publicString getLoginName() {
        returnloginName;
    }
 
    publicvoid setLoginName(String loginName) {
        this.loginName = loginName;
    }
 
    publicString getPassword() {
        returnpassword;
    }
 
    publicvoid setPassword(String password) {
        this.password = password;
    }
 
    publicString getAddress() {
        returnaddress;
    }
 
    publicvoid setAddress(String address) {
        this.address = address;
    }
 
    publicRole getRole() {
        returnrole;
    }
 
    publicvoid setRole(Role role) {
        this.role = role;
    }
}</span>

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
Java中,`@Field`是一个注解,通常用于声明类的属性,可以用于指定属性的名称、类型、默认值等信息。下面是`@Field`的详解: 1. 声明属性 `@Field`可以用于声明类的属性,例如: ``` public class Person { @Field private String name; @Field private int age; } ``` 这里,我们使用`@Field`注解声明了`name`和`age`两个属性。 2. 指定属性名称 可以使用`@Field`注解的`name`属性指定属性的名称,例如: ``` public class Person { @Field(name = "personName") private String name; @Field(name = "personAge") private int age; } ``` 这里,我们使用`@Field`注解的`name`属性分别指定了`name`和`age`的属性名称为`personName`和`personAge`。 3. 指定属性类型 可以使用`@Field`注解的`type`属性指定属性的类型,例如: ``` public class Person { @Field(type = FieldType.TEXT) private String name; @Field(type = FieldType.INTEGER) private int age; } ``` 这里,我们使用`@Field`注解的`type`属性分别指定了`name`和`age`的属性类型为`TEXT`和`INTEGER`。 4. 指定属性默认值 可以使用`@Field`注解的`defaultValue`属性指定属性的默认值,例如: ``` public class Person { @Field(defaultValue = "John") private String name; @Field(defaultValue = "18") private int age; } ``` 这里,我们使用`@Field`注解的`defaultValue`属性分别指定了`name`和`age`的属性默认值为`John`和`18`。 总之,`@Field`注解可以帮助开发者更方便地管理类的属性,提高代码可读性和可维护性。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值