Java反射:

 package com.corn;

 import java.lang.reflect.Constructor;
import java.lang.reflect.Field;
import java.lang.reflect.InvocationTargetException;
import java.lang.reflect.Method; public class TestReflect { public static void main(String[] args) { // 获取“类类型对象” 方法1
Class<?> c0 = User.class; // 获取“类类型对象” 方法2
User user1 = new User();
Class<?> c1 = user1.getClass(); User user2 = new User();
Class<?> c2 = user2.getClass(); System.out.println("user class instance 0:" + c0); //user class instance 0:class com.corn.User
System.out.println("user class instance 1:" + c1); //user class instance 1:class com.corn.User
System.out.println("user class instance 2:" + c2); //user class instance 2:class com.corn.User //c0 == c1 :true, c1 == c2 :true
System.out.println("c0 == c1 :" + (c0 == c1) + ", c1 == c2 :" + (c1 == c2)); try {
// 获取“类类型对象” 方法3
Class<?> c3 = Class.forName("com.corn.User");
System.out.println("user class c3:" + c3); //user class c3:class com.corn.User try {
User user3 = (User) c3.newInstance(); //Constructor public com.corn.User(int,java.lang.String,int)
//Constructor public com.corn.User(int,java.lang.String)
//Constructor public com.corn.User()
Constructor<?>[] cons = c3.getConstructors();
for (int i = 0; i < cons.length; i++) {
// 一次返回类定义中所有public修饰符修饰的“构造器对象”,其与类定义中的构造器顺序不一定相同
System.out.println("Constructor " + cons[i]);
} try {
User user4 = (User) cons[1].newInstance(51, "corn");
//user instance 4:user instance uid:51 name:corn
System.out.println("user instance 4:" + user4); // 返回特定参数类型的“构造器对象”所新建的实例
User user40;
user40 = (User) c3.getConstructor(int.class, String.class).newInstance(520, "corn0");
//user instance 40:user instance uid:520 name:corn0
System.out.println("user instance 40:" + user40); // 返回该类“类类型对象”的所有的父类“类类型对象”
Class<?> father = c3.getSuperclass();
//father class instance class com.corn.Person
System.out.println("father class instance " + father); //返回类对象所有的接口对象(其实也是类类型对象)数组
Class<?>[] interfaceArray = c3.getInterfaces();
//interface class instance 0 interface com.corn.Workable
//interface class instance 1 interface com.corn.Thinkable
for (int i = 0; i < interfaceArray.length; i++) {
// 与implements中接口顺序相同
System.out.println("interface class instance " + i + " " + interfaceArray[i]);
} } catch (IllegalArgumentException e) {
e.printStackTrace();
} catch (InvocationTargetException e) {
e.printStackTrace();
} } catch (InstantiationException e) {
e.printStackTrace();
} catch (IllegalAccessException e) {
e.printStackTrace();
}
} catch (ClassNotFoundException e) {
e.printStackTrace();
} catch (Exception e) {
e.printStackTrace();
} // 返回“类类型对象”所具有的全部属性实例/对象
Field[] fieldArray = c0.getDeclaredFields();
//filed 0 private int com.corn.User.uid
//filed 1 private java.lang.String com.corn.User.name
//filed 2 private int com.corn.User.age
for (int i = 0; i < fieldArray.length; i++) {
System.out.println("filed " + i + " " + fieldArray[i]);
} User u = new User(12, "yumidi", 99); try {
// 直接获取private/私有属性的值
Field nameField = c0.getDeclaredField("name");
//取消Java对访问修饰符的检查
nameField.setAccessible(true);
String nameValue = (String) nameField.get(u);
//name:yumidi
System.out.println("name:" + nameValue); // 直接改变private/私有属性的值
nameField.set(u, "corn");
//new name:corn
System.out.println("new name:" + u.getName()); } catch (NoSuchFieldException e) {
e.printStackTrace();
} catch (SecurityException e) {
e.printStackTrace();
} catch (Exception e) {
e.printStackTrace();
} //访问私有方法
try {
Method method = c0.getDeclaredMethod("getResult");
//取消Java对访问修饰符的检查
method.setAccessible(true);
int result = (int) method.invoke(u);
//result:1000
System.out.println("result:" + result); } catch (NoSuchMethodException e) {
e.printStackTrace();
} catch (SecurityException e) {
e.printStackTrace();
} catch (Exception e) {
e.printStackTrace();
} }
} class User extends Person implements Workable, Thinkable { private int uid;
private String name;
private int age; public User() { } private User(int uid) {
this.uid = uid;
} protected User(String name) {
this.name = name;
} public User(int uid, String name) {
this.uid = uid;
this.name = name;
} public User(int uid, String name, int age) {
this.uid = uid;
this.name = name;
this.age = age;
} public int getUid() {
return uid;
} public void setUid(int uid) {
this.uid = uid;
} public String getName() {
return name;
} public void setName(String name) {
this.name = name;
} public int getAge() {
return age;
} public void setAge(int age) {
this.age = age;
} private int getResult() {
return 1000;
} @Override
public String toString() {
return "user instance uid:" + this.uid + " name:" + this.name;
} } class Person { } interface Workable { } interface Thinkable { }

Java总结篇系列:Java 反射的更多相关文章

  1. Java总结篇系列:Java String

    String作为Java中最常用的引用类型,相对来说基本上都比较熟悉,无论在平时的编码过程中还是在笔试面试中,String都很受到青睐,然而,在使用String过程中,又有较多需要注意的细节之处. 1 ...

  2. Java总结篇系列:Java多线程(三)

    本文主要接着前面多线程的两篇文章总结Java多线程中的线程安全问题. 一.一个典型的Java线程安全例子 public class ThreadTest { public static void ma ...

  3. Java总结篇系列:Java多线程(二)

    本文承接上一篇文章<Java总结篇系列:Java多线程(一)>. 四.Java多线程的阻塞状态与线程控制 上文已经提到Java阻塞的几种具体类型.下面分别看下引起Java线程阻塞的主要方法 ...

  4. Java总结篇:Java多线程

    Java总结篇系列:Java多线程 多线程作为Java中很重要的一个知识点,在此还是有必要总结一下的. 一.线程的生命周期及五种基本状态 关于Java中线程的生命周期,首先看一下下面这张较为经典的图: ...

  5. java提高篇-----理解java的三大特性之封装

    在<Think in java>中有这样一句话:复用代码是Java众多引人注目的功能之一.但要想成为极具革命性的语言,仅仅能够复制代码并对加以改变是不够的,它还必须能够做更多的事情.在这句 ...

  6. Java总结篇系列:java.lang.Object

    从本篇开始,将对Java中各知识点进行一次具体总结,以便对以往的Java知识进行一次回顾,同时在总结的过程中加深对Java的理解. Java作为一个庞大的知识体系,涉及到的知识点繁多,本文将从Java ...

  7. Java总结篇系列:Java多线程(四)

    ThreadLocal是什么 早在JDK 1.2的版本中就提供java.lang.ThreadLocal,ThreadLocal为解决多线程程序的并发问题提供了一种新的思路.使用这个工具类可以很简洁地 ...

  8. Java面试题系列 ----- Java基础面试题(91道)

    更多详情点击查看,点这里!这里!!这里!!! 文末获取所有面试PDF文档! Java概述 1. 何为编程 编程就是让计算机为解决某个问题而使用某种程序设计语言编写程序代码,并最终得到结果的过程. 为了 ...

  9. Java内功修炼系列一反射

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

随机推荐

  1. C#Light/Evil合体啦

    决定将C#Light和C#Evil合并成一个项目,毕竟C#Evil包含C#Light所有的功能,分开两个,基本的表达式方面有什么bug还得两头改 暂时就C#Light/Evil这么叫吧,庆祝合体,画了 ...

  2. Asp.net MVC JsonResult 忽略属性

    指定 JavaScriptSerializer 不序列化公共属性或公共字段.无法继承此类. 命名空间:  System.Web.Script.Serialization 程序集:  System.We ...

  3. [安卓] 14、安卓HTTP——POST和GET用法分析

    内容简介 本文通过建立一个简单的Servlet服务器来分析安卓上用HTTP和服务器通信的细节,旨在演示C/S模式下服务器端和客户端的工作过程. 目录 part.1 用MyEclipse建立一个简单的s ...

  4. Android 数据传递(二)Activity与fragment之间的通信

    在网上找到了一篇总结的非常好的文章,我这里就贴出他的博文地址.自己就不再写这个方面的总结了. Activity与Fragment通信(99%)完美解决方案

  5. Atitit js中的依赖注入di ioc的实现

    Atitit js中的依赖注入di ioc的实现 全类名(FQCN)为标识符1 混合请求模式1 使用类内  builder  即可..2 Service locator method走ok拦2 Jav ...

  6. JS 内置对象

    内置对象的定义:有ECMAScript实现提供的.不依赖与宿主环境的对象,在ECMAScript运行之前就已经创建好的对象就叫做内置对象. 就是说,是不需要我们开发人员先是的实例化对象就能够调用和运行 ...

  7. 【原创】NIO框架入门(四):Android与MINA2、Netty4的跨平台UDP双向通信实战

    概述 本文演示的是一个Android客户端程序,通过UDP协议与两个典型的NIO框架服务端,实现跨平台双向通信的完整Demo. 当前由于NIO框架的流行,使得开发大并发.高性能的互联网服务端成为可能. ...

  8. python的继承

    继承是面向对象的重要特征之一,继承是两个类或者多个类之间的父子关系,子进程继承了父进程的所有公有实例变量和方法.继承实现了代码的重用.重用已经存在的数据和行为,减少代码的重新编写,python在类名后 ...

  9. CCNA网络工程师学习进程(1)网络的基本概述

        在互联网快速发展的今天,了解互联网成为一项必须的技能,因此在学习编程之余学习如何配置网络还是很有必要的. 本系列博客计划分为三个部分,包括思科CCNA.CCNP和华为的网络工程师认证有关的知识 ...

  10. 关于Ubuntu运行级别、开机启动脚本的说明

    关于Ubuntu运行级别.开机启动脚本的说明 目录简介 1.1介绍Ubuntu下面的自启动脚本目录 1.2 Linux操作系统运行级别的概念 1.3关于操作系统自启脚本的启动顺序 1.4    Lin ...