GNN手写字体识别java,Java中反射机制(Reflection)研究及源码演示

如下内容内容是关于 Java中反射机制(Reflection)研究及演示的内容。

package com.jiangqq.reflection;

import java.lang.reflect.Method;

public class Reflection1 {

public static void main(String[] args) throws Exception {

Class> tClass = Class.forName("java.lang.Class");

Method[] methods = tClass.getDeclaredMethods();

for (Method method : methods) {

System.out.println(method);

}

}

}

(三)查看Class的API发现Class类是ReflectionAPI中的核心类,它有以下几个常用的方法①:getName():获得类的完整名字。②:getFields():获得类的public类型的属性。③:getDeclaredFields():获得类的所有属性。④:getMethods():获得类的public类型的方法。⑤:getDeclaredMethods():获得类的所有方法。⑥:getMethod(Stringname,Class[]parameterTypes):获得类的特定方法,name参数指定方法的名字parameterTypes参数指定方法的参数类型。⑦:getConstructors():获得类的public类型的构造方法。⑧:getConstructor(Class[]parameterTypes):获得类的特定构造方法,parameterTypes参数指定构造方法的参数类型。⑨:newInstance():通过类的不带参数的构造方法创建这个类的一个对象。先看上面的⑧和⑨其中都能生成对象,但是因为构造函数有无参和有参构造函数两种,所以我们分两种情况考虑情况一:如果是无参的构造函数来生成对象:首先我们去获取Class对象,然后直接通过Class对象去调用newInstance()方法就可以

Class> tclass = Reflection2.class;

Object reflection2 = classType.newInstance();

首先我们也是去获取Class对象,然后去去调用getConstructor()得到Constructor对象,接着直接调用newInstance()即可

Class> classType = Reflection2.class;

t reflection2 = classType.newInstance();

Constructor> constructor = classType.getConstructor(new Class[] {});

reflection2 = constructor.newInstance(new Object[] {});

情况二:现在是有参构造函数,那我们只有一种方法来通过反射生成对象:

Class> tClass = Person.class;

Constructor cons = classType.getConstructor(new Class[]{String.class, int.class});

Object obj = cons.newInstance(new Object[]{“zhangsan”, 19});

接下来根据以上的一些常用的方法,使用反射举几个例子(使用反射来访问类中的方法):

package com.jiangqq.reflection;

import java.lang.reflect.Constructor;

import java.lang.reflect.Method;

public class Reflection2 {

public int sum(int a, int b) {

return a + b;

}

public String addStr(String str) {

return "This is the:" + str;

}

public static void main(String[] args) throws Exception {

Class> classType = Reflection2.class;

Constructor> constructor = classType.getConstructor(new Class[] {});

Object reflection2 = constructor.newInstance(new Object[] {});

Method sumMethod = classType.getMethod("sum", new Class[] { int.class,

int.class });

Object result1 = sumMethod.invoke(reflection2, new Object[] { 6, 10 });

System.out.println((Integer) result1);

Method addStrMethod = classType.getMethod("addStr",

new Class[] { String.class });

Object result2 = addStrMethod.invoke(reflection2,

new Object[] { "tom" });

System.out.println((String) result2);

}

}

④:通过反射机制调用对象的私有方法,访问对象的私有变量....我们大家都知道,在Java语言中,如果我们对某些变量,或者方法进行private的声明,然后我们在其他类中进行不能去调用这些方法和变量,但是通过反射机制,这些私有声明将不复存在【提醒一点:在写程序的时候,我们最好不要故意经常去使用反射机制来打破这种私有保护...】要实现这种功能,我们需要用到AccessibleObject类中的publicvoidsetAccessible(booleanflag)方法:使用这个方法,把参数flag设置成true,然后我们的field或者method就可以绕过Java语言的语法访问的检查具体使用如下:使用反射去访问私有方法

package com.jiangqq.reflection;

public class Test01 {

private String getName(String name) {

return "This i:" + name;

}

}

package com.jiangqq.reflection;

import java.lang.reflect.Method;

public class TestPrivate01 {

public static void main(String[] args) throws Exception {

Test01 p = new Test01();

Class> classType = p.getClass();

Method method = classType.getDeclaredMethod("getName",

new Class[] { String.class });

method.setAccessible(true);

Object object = method.invoke(p, new Object[] { "tom" });

System.out.println((String)object);

}

}

使用反射机制去访问私有变量:

package com.jiangqq.reflection;

public class Test02 {

private String name="张三";

private String getName()

{

return name;

}

}

package com.jiangqq.reflection;

import java.lang.reflect.Field;

import java.lang.reflect.Method;

public class TestPrivate02 {

public static void main(String[] args) throws Exception {

Test02 p = new Test02();

Class> classType = p.getClass();

Field field = classType.getDeclaredField("name");

field.setAccessible(true);

field.set(p, "李四");

Method method = classType.getDeclaredMethod("getName", new Class[] {});

method.setAccessible(true);

Object object = method.invoke(p, new Object[] {});

System.out.println((String) object);

}

}

人工智能(AI)最近经历了复兴,在视觉,语言,控制和决策等关键领域取得了重大进展。 部分原因在于廉价数据和廉价计算资源,这些资源符合深度学习的自然优势。 然而,在不同的压力下发展的人类智能的许多定义特征仍然是当前方法无法实现的。 特别是,超越一个人的经验 - 从婴儿期开始人类智能的标志 - 仍然是现代人工智能的一项艰巨挑战。 以下是部分立场文件,部分审查和部分统一。我们认为组合概括必须是AI实现类似人类能力的首要任务,结构化表示和计算是实现这一目标的关键。就像生物学利用自然和培养合作一样,我们拒绝“手工工程”和“端到端”学习之间的错误选择,而是倡导一种从其互补优势获益的方法。我们探索如何在深度学习架构使用关系归纳偏差来促进对实体,关系和组成它们的规则的学习。我们为AI工具包提供了一个新的构建模块,具有强大的关系归纳偏差 - 图形网络 - 它概括和扩展了在图形上运行的神经网络的各种方法,并为操纵结构化知识和生成结构化行为提供了直接的界面。我们讨论图网络如何支持关系推理和组合泛化,为更复杂,可解释和灵活的推理模式奠定基础。作为本文的配套文件,我们还发布了一个用于构建图形网络的开源软件库,并演示了如何在实践使用它们。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值