/**
*@file_name Teacher.java
*@package_name com.luke
*@project_name InterviewQuestions
*@descripton
*@author luke
*@time 2013-1-21:下午10:41:11
*@version
*/
package com.luke;
/**
*@descripton
*@author luke
*@time 2013-1-21
*@version
*/
public class Worker
{
public String name;
protected int age;
private double salary;
public Worker(String name)
{
this.name = name;
}
protected Worker(int age)
{
this.age = age;
}
private Worker(double salary)
{
this.salary = salary;
}
public String getName()
{
return name;
}
protected int getAge()
{
return age;
}
private double getSalary()
{
return salary;
}
}
public static void main(String[] args)
{
try
{
Class clsWorker = Class.forName("com.luke.Worker");
Constructor[] allPublicConstructors = clsWorker.getConstructors();
System.out.println("all public constructors(including declared and extending from parent as fllows:");
for (Constructor con : allPublicConstructors)
{
System.out.println(con);
}
System.out.println("-----------------------");
Constructor[] allDeclaredConstructors = clsWorker.getDeclaredConstructors();
System.out.println("all declared constructors(including only in current class exclusive extending from parent) as fllows:");
for (Constructor con : allDeclaredConstructors)
{
System.out.println(con);
}
Constructor publicConstructor = clsWorker.getConstructor(String.class);
Worker publicWorker = (Worker)publicConstructor.newInstance("luke");
Constructor protectedConstructor = clsWorker.getDeclaredConstructor(int.class);
Worker protectedWorker = (Worker)protectedConstructor.newInstance(20);
Constructor privateConstructor = clsWorker.getDeclaredConstructor(double.class);
privateConstructor.setAccessible(true);//must not forget this, when use private constructor!
Worker privateWorker = (Worker)privateConstructor.newInstance(8888.8);
System.out.println("-----------------------");
Field[] allPublicFields = clsWorker.getFields();
System.out.println("all public fields as fllows:");
for (Field field : allPublicFields)
{
System.out.println(field.getName());
}
System.out.println("-----------------------");
Field[] allDeclaredFields = clsWorker.getDeclaredFields();
System.out.println("all declared fields as fllows:");
for (Field field : allDeclaredFields)
{
System.out.println(field.getName());
}
System.out.println("-----------------------");
Field salary = clsWorker.getDeclaredField("salary");
salary.setAccessible(true);//must not forget this, when access private field!
System.out.println("before reset salary===" + salary.get(privateWorker));
salary.set(privateWorker, 99999.9);
System.out.println("after reset salary===" + salary.get(privateWorker));
System.out.println("-----------------------");
Method[] allPublicMethods = clsWorker.getMethods();
System.out.println("all public methods as fllows:");
for (Method method : allPublicMethods)
{
System.out.println(method);
}
System.out.println("-----------------------");
Method[] allDeclaredMethods = clsWorker.getDeclaredMethods();
System.out.println("all declared methods as fllows:");
for (Method method : allDeclaredMethods)
{
System.out.println(method);
}
System.out.println("-----------------------");
Method privateMethod = clsWorker.getDeclaredMethod("getSalary", null);
System.out.println("is method accessible===" + privateMethod.isAccessible());
privateMethod.setAccessible(true);//must not forget this, when access private method!
System.out.println("getSalary()===" + privateMethod.invoke(privateWorker, null));
}
catch (ClassNotFoundException e)
{
// TODO Auto-generated catch block
e.printStackTrace();
}
catch (SecurityException e)
{
// TODO Auto-generated catch block
e.printStackTrace();
}
catch (NoSuchMethodException e)
{
// TODO Auto-generated catch block
e.printStackTrace();
}
catch (IllegalArgumentException e)
{
// TODO Auto-generated catch block
e.printStackTrace();
}
catch (InstantiationException e)
{
// TODO Auto-generated catch block
e.printStackTrace();
}
catch (IllegalAccessException e)
{
// TODO Auto-generated catch block
e.printStackTrace();
}
catch (InvocationTargetException e)
{
// TODO Auto-generated catch block
e.printStackTrace();
}
catch (NoSuchFieldException e)
{
// TODO Auto-generated catch block
e.printStackTrace();
}
}
}
####output####
all public constructors as fllows:
public com.luke.Worker(java.lang.String)
-----------------------
all declared constructors as fllows:
public com.luke.Worker(java.lang.String)
protected com.luke.Worker(int)
private com.luke.Worker(double)
-----------------------
all public fields as fllows:
name
-----------------------
all declared fields as fllows:
name
age
salary
-----------------------
before reset salary===8888.8
after reset salary===99999.9
-----------------------
all public methods as fllows:
public java.lang.String com.luke.Worker.getName()
public final native void java.lang.Object.wait(long) throws java.lang.InterruptedException
public final void java.lang.Object.wait() throws java.lang.InterruptedException
public final void java.lang.Object.wait(long,int) throws java.lang.InterruptedException
public boolean java.lang.Object.equals(java.lang.Object)
public java.lang.String java.lang.Object.toString()
public native int java.lang.Object.hashCode()
public final native java.lang.Class java.lang.Object.getClass()
public final native void java.lang.Object.notify()
public final native void java.lang.Object.notifyAll()
-----------------------
all declared methods as fllows:
public java.lang.String com.luke.Worker.getName()
private double com.luke.Worker.getSalary()
protected int com.luke.Worker.getAge()
-----------------------
is method accessible===false
getSalary()===99999.9
分享到:
相关推荐
Java反射是Java编程语言中的一个重要特性,它允许程序在运行时动态地获取类的信息并操作类的对象。在Java中,反射机制提供了强大的能力,包括在运行时检查类的结构、创建对象实例、调用方法以及访问和修改字段值。...
Java反射是Java编程语言中的一个强大工具,它允许运行中的Java程序对自身进行检查并且可以直接操作程序的内部属性。在Java中,反射主要用于在运行时分析类和对象,包括访问私有成员、调用私有方法、创建对象、获取类...
Java反射机制是Java编程语言中的一个强大特性,它允许运行中的Java程序对自身进行检查并且可以直接操作程序的内部属性。这个特性使得Java具有了高度的灵活性和动态性,尤其是在处理元数据、创建对象、调用私有方法...
Java反射机制是Java语言提供的一种强大功能,它允许运行中的Java程序对自身进行检查并且可以直接操作程序的内部属性。在Java中,反射机制的核心类是java.lang.Class,它代表了运行时的类信息。通过Class对象,我们...
在本文中,我们将深入探讨如何使用Java反射来获取并执行某个特定的方法。 首先,我们需要了解Java反射的基本概念。`java.lang.Class`类是反射的核心,它代表了Java中的每一个类。我们可以通过以下方式获取到一个...
### Java反射性能测试分析 #### 引言 Java反射机制是Java编程语言中一个强大的特性,它允许程序在运行时动态地访问、检测和修改类、接口、字段和方法等对象。然而,反射操作通常会引入额外的开销,这在性能敏感的...
Java反射是Java编程语言中的一个强大特性,它允许运行时的程序访问并操作类、接口、字段和方法等信息,即使这些信息在编译时并未明确知晓。在Java中,反射通常通过`java.lang.Class`类和相关的API来实现。本实例将...
### Java反射机制详解 #### 一、概述 Java反射机制是一种强大的编程技术,它允许运行时检查类的信息并操作对象的内部结构。本篇将基于Sun公司的官方文档《Java™ Core Reflection API and Specification》(1997年...
### 反射实例—JAVA反射机制 #### 一、反射概念及原理 反射在计算机科学领域,特别是程序设计中,是指程序有能力访问、检测和修改其自身的结构和行为。这一概念最早由Smith于1982年提出,并迅速应用于各种编程语言...
### Java反射机制详解 #### 一、什么是Java反射? Java反射是Java编程语言的一个特性,它允许运行时检查和操作程序结构(类、字段、方法等)。反射的主要用途包括但不限于:动态实例化对象、访问私有成员、调用...
Java反射是Java语言提供的一种强大的动态类型特性,它允许程序在运行时检查类、接口、字段和方法的信息,并且能够动态地创建对象和调用方法。这个能力使得开发者可以突破静态类型的束缚,实现一些在编译时期无法完成...
Java反射是Java编程语言中的一个强大特性,它允许在运行时检查类、接口、字段和方法的信息,并且能够在运行时动态地创建对象和调用方法。这个特性使得Java具有高度的灵活性,尤其在处理框架、插件系统以及元数据驱动...
### Java反射机制详解 #### 一、反射的基本概念与历史背景 反射的概念最早由Smith在1982年提出,其核心思想是程序有能力访问、检测甚至修改自身的状态和行为。这种能力一经提出,迅速成为了计算机科学领域的研究...
### Java反射机制与NoSuchMethodException详解 在Java编程中,反射是一种强大的机制,允许程序在运行时检查和修改自身结构和行为。然而,当开发者尝试使用反射调用一个不存在的方法时,便会遇到`java.lang....
Java反射是Java编程语言中的一个强大工具,它允许运行中的Java程序对自身进行检查并且可以直接操作程序的内部属性。在Java中,反射主要用于在运行时分析类和对象,包括访问私有成员、调用私有方法、创建动态代理等。...
Java反射是Java编程语言中的一个强大工具,它允许运行中的Java程序对自身进行检查并且可以直接操作程序的内部属性。在给定的“利用java反射将json字符串转成对象”的主题中,我们将深入探讨如何借助反射机制将JSON...
### Java反射机制详解 #### 一、什么是Java反射机制? Java反射机制是在运行状态中,对于任意一个类,都能够知道这个类的所有属性和方法;对于任意一个对象,都能够调用它的任意一个方法和属性;这种动态获取的...
Java反射机制是Java编程语言中的一个强大工具,它允许程序在运行时检查并操作类、接口、字段和方法等对象。在"北大青鸟java反射机制"的学习资料中,我们将会深入探讨这一核心特性。 首先,我们要理解反射的核心概念...