java工程积累——java 反射 invoke

引:

在java项目中,我们听了很多ORM的概念,我就一直耿耿于怀,怎么就从rs转换成了对象呢?难道要写非常多的判断吗?答案肯定是否定,我们就要探索怎么解决这个问题,刚好在研究我们系统底层架构的时候,挖掘了这一点,现在和大家分享:

深入:

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

Java反射机制主要提供了以下功能:在运行时判定任意一个对象所属的类;在运行时构造任意一个类的对象;在运行时判定任意一个类所具有的成员变量和方法;在运行时调用任意一个对象的方法;生成动态代理。

<span style="font-size:18px;">package com.java.jvm;

import java.lang.reflect.*;

class InvokeTest {
	public static void main(String[] args) {
		 try {
			 Class c = Class.forName("com.java.jvm.User");
			 Object o = c.newInstance();
			 Method m = c.getMethod("getName", null);
			 Object ret = m.invoke(o, null);
			 System.out.println( "com.java.jvm.User.getName() = " + ret);

			 m = c.getMethod("setName", new Class[]{String.class});
			 ret = m.invoke(o, new Object[]{"shengjian"});
			 System.out.println( "com.java.jvm.User.setName() = " + ret);

			 m = c.getMethod("getName", null);
			 ret = m.invoke(o, null);
			 System.out.println( "com.java.jvm.User.getName() = " + ret);

			 //静态方法的调用
			 m = c.getMethod("getUserName", new Class[]{String.class});
			 ret = m.invoke(null, "fuwang");
			 System.out.println( "com.java.jvm.User.getUserName() = " + ret);

		 } catch (ClassNotFoundException ex) {
			System.out.println("找不到此类别");
		 } catch (NoSuchMethodException ex) {
			System.out.println("此方法不存在");
		 } catch (IllegalAccessException ex) {
			System.out.println("没有权限调用此方法");
		 } catch (InvocationTargetException ex) {
			System.out.println("调用此方法时发生下列例外:\n" + ex.getTargetException());
		 } catch (IllegalArgumentException e) {
			e.printStackTrace();
		 } catch (InstantiationException e) {
			e.printStackTrace();
		 }
	 }
}</span>

c.getMethod("getName", null)返回一个 Method 对象,它反映此 Class 对象所表示的类或接口的指定公共成员方法。name 参数是一个String,用于指定所需方法的简称。parameterTypes 参数是按声明顺序标识该方法形参类型的 Class 对象的一个数组。如果  parameterTypes 为 null,则按空数组处理。      name - 方法名 parameterTypes
- 参数列表Method 提供关于类或接口上单独某个方法(以及如何访问该方法)的信息。所反映的方法可能是类方法或实例方法(包括抽象方法)。

invoke()

对带有指定参数的指定对象调用由此 Method 对象表示的底层方法。个别参数被自动解包,以便与基本形参相匹配,基本参数和引用参数都随需服从方法调用转换。如果底层方法是静态的,那么可以忽略指定的 obj 参数。该参数可以为 null。如果底层方法所需的形参数为 0,则所提供的 args 数组长度可以为 0 或 null。如果底层方法是实例方法,则使用动态方法查找来调用它,这一点记录在 Java Language Specification,
Second Edition 的第 15.12.4.4 节中;在发生基于目标对象的运行时类型的重写时更应该这样做。如果底层方法是静态的,并且尚未初始化声明此方法的类,则会将其初始化。如果方法正常完成,则将该方法返回的值返回给调用者;如果该值为基本类型,则首先适当地将其包装在对象中。但是,如果该值的类型为一组基本类型,则数组元素不 被包装在对象中;换句话说,将返回基本类型的数组。如果底层方法返回类型为 void,则该调用返回 null。

obj - 从中调用底层方法的对象args - 用于方法调用的参数。

User代码:

<span style="font-size:18px;">package com.java.jvm;

public class User {

    static{
        System.out.println("static ---");
    }

    public User(){
        System.out.println("name="+name);
        name="xiaotian";
    }

    private String name;
    private Integer age;
    private String address;

    public static String getUserName(String name){
        return name;
    }
    public String getName() {
        return name;
    }
    public void setName(String name) {
        this.name = name;
    }
    public Integer getAge() {
        return age;
    }
    public void setAge(Integer age) {
        this.age = age;
    }
    public String getAddress() {
        return address;
    }
    public void setAddress(String address) {
        this.address = address;
    }
    @Override
    public String toString() {
        return "User [name=" + name + ", age=" + age + ", address=" + address
                + "]";
    }

}</span>

总结:

在我们为了某个实现而辗转反侧,夜不能寐的时候,有一天我们暮然发现,原来这一切竟是如此的简单,java本省的架构和底层,有着无穷的美丽指引着我们去探索和发现!在这个过程中,我们解开java这个虚掩的门缝,查看里面无尽的风光!

编程很奇妙,有时,需要我们广泛,有时,需要我们深入!

时间: 2024-10-23 21:04:41

java工程积累——java 反射 invoke的相关文章

java工程积累——如何处理Tomcat内存溢出

在项目的部署中,我们设置不当,有时会常常遇到一个bug,就是内存溢出,而在百般调试,释放资源之后,却还是没有解决,这时,不要着急,我们静下心来,在数据量,代码量都不多情况下,并且不是很经常出现这bug时,我们要进行一下小小的总结,来处理这类事件的发生! 错误 我们先看,内存溢出的提示,一般会有三种,我们一一看看: 这里根据平时遇到的情况和相关资料进行一个总结.常见的一般会有下面三种情况: 1.OutOfMemoryError: Java heap space 2.OutOfMemoryError

java工程积累——前台页面的统一校验

在项目中,我们面临这样的问题,就是如果在前台做抽象,大家想想后台代码的抽象,我们耳熟能详,但是前台的抽象,我们是如何做的呢?恐怕这个问题,如果是第一次抛给自己,自己也很惶恐,就是,我们不是对应一个业务写好一个页面吗?以前从来没有想过抽象,这里,我就要说,那是咱们最初级的方式,今天带大家一起见证先比较靠谱一种方式! 回顾 我们回顾下html编码的历程,在web1.0时代,我们面向的大多是静态页面,这时候,能够展示出来就好,由于网速的限制,电脑处理能力的约束,我们只能把什么都写在一起,但是随着时间的

java工程积累——项目管理:破窗理论

年后这段时间,我一直带着项目,在项目中,最后总会遇到这样那样的问题,搞得自己有些狼狈!在向我的恩师求助后,我翻阅了一些资料和书籍,最后找到了一个特别有意思的问题!就是咱们的题目,破窗理论,咱们一起来探讨探讨. 百科-破窗理论: 一个房子如果窗户破了,没有人去修补,隔不久,其它的窗户也会莫名其妙地被人打破:一面墙,如果出现一些涂鸦没有被清洗掉,很快的,墙上就布满了乱七八糟.不堪入目的东西:一个很干净的地方,人们不好意思丢垃圾,但是一旦地上有垃圾出现之后,人就会毫不犹豫地抛,丝毫不觉羞愧. 当然,这

java工程积累——加密hibernate数据源连接符

最近很多公司因为安全问题被各种折磨,我们公司出于这方面的考虑,需要对数据库连接进行加密,在网上很容易就找到了解决方案,在这里分享给大家,但是这个解决方案的内容,也引起了我对程序的思考! 解决方案: 环境要求: Spring管理数据库连接 配置步骤 1,  配置spring文件 <span style="font-size:18px;"><!-加密解密类--> <!-加密解密类:因为它继承了配置类,所以它可以更改配置规则--> <beanclas

java工程积累——saas之multi-tenancy解析

最近做的项目涉及到比较深入的一部分,就是定义客户关系,在我们的商讨中,我们决定,采用服务商的模式,就是我们是基础服务商,由客户组合服务,向客户提供基于云端的服务支持!这就自然引出了以下概念: saas百科: SaaS是Software-as-a-Service(软件即服务)的简称,随着互联网技术的发展和应用软件的成熟, 在21世纪开始兴起的一种完全创新的软件应用模式.它与"on-demand software"(按需软件),the application service provide

java工程积累——树形结构的操作

最近一直被树形结构整的很头大,又是递归,又是循环,但是,好在我们在经历了千辛万苦后,终于弄出来了,其实就是组织机构的常规操作,有些是我们过度设计,有些是我们想错了,而对数的逻辑读取,我们就属于想错了的类型,今天拿出来和大家分享,主要是树形结构在数据库的读取问题! 原始: 在最开始,我们对树的查询,肯定是从最简单的select开始,我们现在回顾一下: 定义: 表名:tb_tree 字段:id(主键),title(标题),parentId(父节点id) 举例: 1.查找树中的所有顶级父节点(辈份最长

java工程积累——权限验证在Ajax中失效的解决方案

最近在公司做的项目一直测试和使用都很好,客户反响也很不错,但是,就在前两天,客户提出了一个bug,但是全队都愁眉不展,在今天做公交车的时候,我突然想到了一种可能,就是我们习以为常的ajax提交出了问题! 起因: 需求:在判断用户session有没有超时的情况,我们使用的是在所有的请求前通过aop进行判断,如果session中,用户登录信息丢失,则重新登录,否则继续! bug情况:在页面提交,跳转下正常判断,但是在用户session过期后,直接使用Ajax提交时,提交失败! 初期方案: 方案1:

Gradle 教程说明 用户指南 第7章 构建Java工程----快速入门

官网地址:http://www.gradle.org/docs/2.1/userguide/tutorial_java_projects.html A basic Java project  一个基础的java工程 使用java插件在build.gradle: apply plugin: 'java' Building the project 构建工程 这里使用gradle/samples/java/quickstart  示例工程.shell进该目录. > gradle build 命令所 运

JAVA深入研究——Method的Invoke方法。

在写代码的时候,发现从父类class通过getDeclaredMethod获取的Method可以调用子类的对象,而子类改写了这个方法,从子类class通过getDeclaredMethod也能获取到Method,这时去调用父类的对象也会报错.虽然这是很符合多态的现象,也符合java的动态绑定规范,但还是想弄懂java是如何实现的,就学习了下Method的源代码. Method的invoke方法 1.先检查 AccessibleObject的override属性是否为true. Accessibl