1 public class Demo02 {
2 @SuppressWarnings("all")
3 public static void main(String[] args) throws Exception {
4 // 另一个com.sg.myReflection.bean包下的User类
5 String path = "com.sg.myReflection.bean.User";
6 try {
7 Class clazz = Class.forName(path);
8         // User.class new User().getClass()
9 // 获取类名
10 String strName01 = clazz.getName();// 获取完整类名com.sg.myReflection.bean.User
11 String strName02 = clazz.getSimpleName();// 直接获取类名 User
12
13 // 获取属性
14 Field[] field01 = clazz.getFields(); // 返回属性为public的字段
15 Field[] field02 = clazz.getDeclaredFields(); // 返回所有的属性
16 Field field03 = clazz.getDeclaredField("id"); // 获取属性为id的字段
17
18 // 获取普通方法
19 Method[] Method01 = clazz.getDeclaredMethods(); // 返回public方法
20 Method method = clazz.getDeclaredMethod("getId", null); // 返回getId这个方法,如果没有参数,就默认为null
21
22
23 // 获取构造方法
24 User u1 = (User) clazz.newInstance(); // 获取无参的构造函数这里的前提的保证类中应该有无参的构造函数
25 // 获取参数为(int,String,int)的构造函数
26 Constructor c2 = clazz.getDeclaredConstructor(int.class, String.class, int.class);
27 // 通过有参构造函数创建对象
28 User u2 = (User) c2.newInstance(1001, "小小", 18);
29
30
31 // 通过反射调用普通方法
32 User u3 = (User) clazz.newInstance();
33 Method method03 = clazz.getDeclaredMethod("setId", int.class);
34 method.invoke(u3, 1002); // 把对象u3的id设置为1002
35
36
37
38 // 通过反射操作普通的属性
39 User u4 = (User) clazz.newInstance();
40 Field f = clazz.getDeclaredField("name");
41 f.setAccessible(true); // 设置属性可以直接的进行访问
42 f.set(u4, "石头");
43
44 } catch (ClassNotFoundException e) {
45 e.printStackTrace();
46 }
47 }
48 }
  1 public static void getObjectValue(Object object) throws Exception {
2 //我们项目的所有实体类都继承BaseDomain (所有实体基类:该类只是串行化一下)
3 //不需要的自己去掉即可
4 if (object != null && object instanceof BaseDomain) {//if (object!=null ) ----begin
5 // 拿到该类
6 Class<?> clz = object.getClass();
7 // 获取实体类的所有属性,返回Field数组
8 Field[] fields = clz.getDeclaredFields();
9
10 for (Field field : fields) {// --for() begin
11 System.out.println(field.getGenericType());//打印该类的所有属性类型
12
13 // 如果类型是String
14 if (field.getGenericType().toString().equals(
15 "class java.lang.String")) { // 如果type是类类型,则前面包含"class ",后面跟类名
16 // 拿到该属性的gettet方法
17 /**
18 * 这里需要说明一下:他是根据拼凑的字符来找你写的getter方法的
19 * 在Boolean值的时候是isXXX(默认使用ide生成getter的都是isXXX)
20 * 如果出现NoSuchMethod异常 就说明它找不到那个gettet方法 需要做个规范
21 */
22 Method m = (Method) object.getClass().getMethod(
23 "get" + getMethodName(field.getName()));
24
25 String val = (String) m.invoke(object);// 调用getter方法获取属性值
26 if (val != null) {
27 System.out.println("String type:" + val);
28 }
29
30 }
31
32 // 如果类型是Integer
33 if (field.getGenericType().toString().equals(
34 "class java.lang.Integer")) {
35 Method m = (Method) object.getClass().getMethod(
36 "get" + getMethodName(field.getName()));
37 Integer val = (Integer) m.invoke(object);
38 if (val != null) {
39 System.out.println("Integer type:" + val);
40 }
41
42 }
43
44 // 如果类型是Double
45 if (field.getGenericType().toString().equals(
46 "class java.lang.Double")) {
47 Method m = (Method) object.getClass().getMethod(
48 "get" + getMethodName(field.getName()));
49 Double val = (Double) m.invoke(object);
50 if (val != null) {
51 System.out.println("Double type:" + val);
52 }
53
54 }
55
56 // 如果类型是Boolean 是封装类
57 if (field.getGenericType().toString().equals(
58 "class java.lang.Boolean")) {
59 Method m = (Method) object.getClass().getMethod(
60 field.getName());
61 Boolean val = (Boolean) m.invoke(object);
62 if (val != null) {
63 System.out.println("Boolean type:" + val);
64 }
65
66 }
67
68 // 如果类型是boolean 基本数据类型不一样 这里有点说名如果定义名是 isXXX的 那就全都是isXXX的
69 // 反射找不到getter的具体名
70 if (field.getGenericType().toString().equals("boolean")) {
71 Method m = (Method) object.getClass().getMethod(
72 field.getName());
73 Boolean val = (Boolean) m.invoke(object);
74 if (val != null) {
75 System.out.println("boolean type:" + val);
76 }
77
78 }
79 // 如果类型是Date
80 if (field.getGenericType().toString().equals(
81 "class java.util.Date")) {
82 Method m = (Method) object.getClass().getMethod(
83 "get" + getMethodName(field.getName()));
84 Date val = (Date) m.invoke(object);
85 if (val != null) {
86 System.out.println("Date type:" + val);
87 }
88
89 }
90 // 如果类型是Short
91 if (field.getGenericType().toString().equals(
92 "class java.lang.Short")) {
93 Method m = (Method) object.getClass().getMethod(
94 "get" + getMethodName(field.getName()));
95 Short val = (Short) m.invoke(object);
96 if (val != null) {
97 System.out.println("Short type:" + val);
98 }
99
100 }
101 // 如果还需要其他的类型请自己做扩展
102
103 }//for() --end
104
105 }//if (object!=null ) ----end
106 }
107
108 // 把一个字符串的第一个字母大写、效率是最高的、
109 private static String getMethodName(String fildeName) throws Exception{
110 byte[] items = fildeName.getBytes();
111 items[0] = (byte) ((char) items[0] - 'a' + 'A');
112 return new String(items);
113 }

有关java之反射的使用的更多相关文章

  1. JAVA的反射理解

    1----------------------------反射的概念----------------------------------------------- JAVA的反射机制是在运行状态中,对 ...

  2. java的反射

    JAVA反射机制是在运行状态中,对于任意一个类,都能够知道这个类的所有属性和方法:对于任意一个对象,都能够调用它的任意方法和属性:这种动态获取信息以及动态调用对象方法的功能称为java语言的反射机制. ...

  3. iOS运行时编程(Runtime Programming)和Java的反射机制对比

    运行时进行编程,类似Java的反射.运行时编程和Java反射的对比如下:   1.相同点   都可以实现的功能:获取类信息.属性设置获取.类的动态加载(NSClassFromString(@“clas ...

  4. Java 类反射机制分析

    Java 类反射机制分析 一.反射的概念及在Java中的类反射 反射主要是指程序可以访问.检测和修改它本身状态或行为的一种能力.在计算机科学领域,反射是一类应用,它们能够自描述和自控制.这类应用通过某 ...

  5. java的反射机制

    一.java的反射机制浅谈 最近研究java研究得很给力,主要以看博文为学习方式.以下是我对java的反射机制所产生的一些感悟,希望各位童鞋看到失误之处不吝指出.受到各位指教之处,如若让小生好好感动, ...

  6. Java:反射

    初识Java反射机制: 从上面的描述可以看出Java的反射机制使得Java语言可以在运行时去认识在编译时并不了解的类/对象的信息,并且能够调用相应的方法或修改属性的值.Java反射机制的核心就是允许在 ...

  7. Java中反射机制和Class.forName、实例对象.class(属性)、实例对象getClass()的区别

    一.Java的反射机制   每个Java程序执行前都必须经过编译.加载.连接.和初始化这几个阶段,后三个阶段如下图:   其中

  8. java笔记--反射进阶之总结与详解

    一.反射进阶之动态设置类的私有域 "封装"是Java的三大特性之一,为了能更好保证其封装性,我们往往需要将域设置成私有的, 然后通过提供相对应的set和get方法来操作这个域.但是 ...

  9. java笔记--反射机制之基础总结与详解

    一.反射之实例化Class类的5种方式: java的数据类型可以分为两类,即引用类型和原始类型(即基本数据类型). 对于每种类型的对象,java虚拟机会实例化不可变的java.lang.Class对象 ...

  10. Java中反射的三种常用方式

    Java中反射的三种常用方式 package com.xiaohao.test; public class Test{ public static void main(String[] args) t ...

随机推荐

  1. Codeforces 463C Gargari and Bishops 题解

    题目出处: http://codeforces.com/contest/463/problem/C 感觉本题还是挺难的.须要好好总结一下. 计算对角线的公式: 1 右斜对角线,也叫主对角线的下标计算公 ...

  2. CentOS6.8 搭建SVN并用钩子自动实现同步到web目录

    一 安装 yum install subversion 二 检查是否安装成功 svn --version 三 创建仓库目录 mkdir –p /home/svnroot/test 四 创建项目 svn ...

  3. (二)Thymeleaf标准表达式之——简单表达式

    2. 标准表达式(Standard Expression Syntax) 标准表达式包含以下几个方面: 简单表达式: 变量表达式: ${...} 选择变量表达式: *{...} 消息表达式: #{.. ...

  4. java读取clob字段的几种方法

    http://cache.baiducontent.com/c?m=9f65cb4a8c8507ed4fece7631046893b4c4380143fd3d1027fa3c215cc790f1a06 ...

  5. systemd管理进程

    systemd很强大的管理工具,这里简单用来管理一个进程: [Unit]Description=Imges Compress Server [Service]Type=simpleExecStart= ...

  6. Maven环境下搭建SSH框架之Spring整合Struts2

    © 版权声明:本文为博主原创文章,转载请注明出处 1.搭建环境 Struts2:2.5.10 Spring:4.3.8.RELEASE 注意:其他版本在某些特性的使用上可能稍微存在差别 2.准备工作 ...

  7. MapReduce源码分析之LocatedFileStatusFetcher

    LocatedFileStatusFetcher是MapReduce中一个针对给定输入路径数组,使用配置的线程数目来获取数据块位置的实用类.它的主要作用就是利用多线程技术,每个线程对应一个任务,每个任 ...

  8. MIC中offload语法总结

    MIC中offload的用法如下: #pragma offload specifier [,specifier...]specifier可以填入的选项为:target 例:taget(mic:0)if ...

  9. Win7系统CMD命令提示符输入中文变乱码怎么办

    Win7系统下经常使用CMD命令提示符进行很多操作,发现Win7旗舰版系统在CMD命令提示符不能输入文字,输入的中文字都变成乱码,这是怎么回事呢?本文将提供Win7系统CMD命令提示符输入中文变乱码的 ...

  10. 【BZOJ3651】网络通信 LCT

    [BZOJ3651]网络通信 Description 有一个由M 条电缆连接的 N 个站点组成的网络.为了防止垄断,由 C 个公司控制所有的电缆,规定任何公司不能控制连接同一个站点的两条以上的电缆(可 ...