• JAVA反射中的getFields()方法和getDeclaredFields ()方法的区别


    JAVA反射中的getFields()方法和getDeclaredFields ()方法的区别

     

    关于获取类的字段有两种方式:getFields()和getDeclaredFields()。我们先来看看这两者的区别吧:

    getFields():获得某个类的所有的公共(public)的字段,包括父类中的字段。 
    getDeclaredFields():获得某个类的所有声明的字段,即包括public、private和proteced,但是不包括父类的申明字段。

    同样类似的还有getConstructors()和getDeclaredConstructors()、getMethods()和getDeclaredMethods(),这两者分别表示获取某个类的方法、构造函数。

    具体编码如下:

    我们先创建一个POJO

    [java] view plaincopy
     
    1. public class User {  
    2.     private long id;  
    3.     private String name;  
    4.   
    5.     public void setId(long id) {  
    6.         this.id = id;  
    7.     }  
    8.   
    9.     public void setName(String name) {  
    10.         this.name = name;  
    11.     }  
    12.   
    13.     public long getId() {  
    14.         return id;  
    15.     }  
    16.   
    17.     public String getName() {  
    18.         return name;  
    19.     }  
    20. }  

    再来获取此类中的所有字段
    Field[] fields = User.class.getDeclaredFields();

    获取字段的名称

    String fieldName = field.getName();

    获取字段的修饰符

    int fieldValue = field.getModifiers();//如:private、static、final等

    与某个具体的修饰符进行比较

    Modifier.isStatic(fieldValue)//看此修饰符是否为静态(static)

    获取字段的声明类型

    field.getType();//返回的是一个class

    与某个类型进行比较

    field.getType() == Timestamp.class

    获取指定对象中此字段的值

    Object fieldObject= field.get(user);//user可以看做是从数据库中查找出来的对象

    如果POJO类中有一个集合类型的字段,我们该如何获取字段中中的值呢?

    首先创建一个POJO类

    [java] view plaincopy
     
    1. public class Bean {  
    2.   
    3.     private String[] love;  
    4.   
    5.     public String[] getLove() {  
    6.         return love;  
    7.     }  
    8.   
    9.     public void setLove(String[] love) {  
    10.         this.love = love;  
    11.     }  
    12. }  

    创建一个操作类

    [java] view plaincopy
     
    1. import java.lang.reflect.Method;  
    2.   
    3. public class Admin {  
    4.   
    5.     public static void main(String[] args) {  
    6.   
    7.         try {  
    8.   
    9.             // 赋值  
    10.             Object obj = Bean.class.newInstance();  
    11.             Class paramClass = Class.forName("[Ljava.lang.String;");  
    12.             String[] param = { "吃", "喝", "玩", "乐" };  
    13.             Method method = Bean.class.getMethod("setLove", paramClass);  
    14.             method.invoke(obj, (Object) param);  
    15.   
    16.             // 取值  
    17.             Bean bean = (Bean) obj;  
    18.             for (int i = 0; i < bean.getLove().length; i++) {  
    19.                 System.out.println(bean.getLove()[i]);  
    20.             }  
    21.             System.out.println();  
    22.         } catch (Exception e) {  
    23.             e.printStackTrace();  
    24.         }  
    25.     }  
    26. }  

    得到的结果为:






    关于field还有一种情况我们需要注意,就是当字段修饰符为private时,我们需要加上:

    field.setAccessible(true);

    判断方法是:if (!field.isAccessible())

    更详细的解释请点击

    接下来补充一下在Java中使用正则表达式

    先创建一个正则表达式对象

    Pattern pattern = Pattern.compile("[A-Z][a-z]*");

    指定为字符串的正则表达式必须首先被编译为此类的实例

    Matcher matcher = pattern.matcher(fieldName);

    尝试查找与该模式匹配的输入序列的下一个子序列

    boolean isMatcher = matcher.find();

    返回由以前匹配操作所匹配的输入子序列

    String str = matcher.group();

    实现非终端添加和替换步骤,以'_'连接各个字段

    matcher.appendReplacement(sb, str + "_");

    原文地址:http://blog.csdn.net/zlb824/article/details/7494300

  • 相关阅读:
    谷歌在线测试题
    C++ 重载(overload)、重写(overrride)、重定义(redefine)总结
    C/S架构和B/S架构的概念和区别
    hadoop 及hbase zookeeper 经常出现问题
    Hadoop上的中文分词与词频统计实践 (有待学习 http://www.cnblogs.com/jiejue/archive/2012/12/16/2820788.html)
    HBase数据的导入和导出
    浅谈hbase表中数据导出导入(也就是备份)
    学习大数据看门的几本书
    hadoop pig入门总结
    Hadoop生态上几个技术的关系与区别:hive、pig、hbase 关系与区别
  • 原文地址:https://www.cnblogs.com/yonyong/p/8571935.html
Copyright © 2020-2023  润新知