「java反射类型转换」java反射的三种方式
今天给各位分享java反射类型转换的知识,其中也会对java反射的三种方式进行解释,如果能碰巧解决你现在面临的问题,别忘了关注本站,现在开始吧!
本文目录一览:
北大青鸟java培训:JAVA反射机制原理?
运行时类型识别(Run-timeTypeIdentification,RTTI)主要有两种方式,一种是我们在编译时和运行时已经知道了所有的类型,另外一种是功能强大的“反射”机制。
要理解RTTI在Java中的工作原理,首先必须知道类型信息在运行时是如何表示的,这项工作是由“Class对象”完成的,它包含了与类有关的信息。
类是程序的重要组成部分,每个类都有一个Class对象,每当编写并编译了一个新类就会产生一个Class对象,它被保存在一个同名的.class文件中。
在运行时,当我们想生成这个类的对象时,运行这个程序的Java虚拟机(JVM)会确认这个类的Class对象是否已经加载,如果尚未加载,JVM就会根据类名查找.class文件,并将其载入,一旦这个类的Class对象被载入内存,它就被用来创建这个类的所有对象。
一般的RTTI形式包括三种:1.传统的类型转换。
如“(Apple)Fruit”,由RTTI确保类型转换的正确性,如果执行了一个错误的类型转换,就会抛出一个ClassCastException异常。
2.通过Class对象来获取对象的类型。
如Classc=Class.forName(“Apple”);Objecto=c.newInstance();3.通过关键字instanceof或Class.isInstance()方法来确定对象是否属于某个特定类型的实例,准确的说,应该是instanceof/Class.isInstance()可以用来确定对象是否属于某个特定类及其所有基类的实例,这和equals()/==不一样,它们用来比较两个对象是否属于同一个类的实例,没有考虑继承关系。
反射如果不知道某个对象的类型,可以通过RTTI来获取,但前提是这个类型在编译时必须已知,这样才能使用RTTI来识别。
即在编译时,编译器必须知道所有通过RTTI来处理的类。
使用反射机制可以不受这个限制,它主要应用于两种情况,第一个是“基于构件的编程”,在这种编程方式中,将使用某种基于快速应用开发(RAD)的应用构建工具来构建项目。
这是现在最常见的可视化编程方法,通过代表不同组件的图标拖动到图板上来创建程序,然后设置构件的属性值来配置它们。
这种配置要求构件都是可实例化的,并且要暴露其部分信息,使得程序员可以读取和设置构件的值。
当处理GUI时间的构件时还必须暴露相关方法的细细,以便RAD环境帮助程序员覆盖这些处理事件的方法。
在这里,就要用到反射的机制来检查可用的方法并返回方法名。
Java通过JavaBeans提供了基于构件的编程架构。
第二种情况,在运行时获取类的信息的另外一个动机,就是希望能够提供在跨网络的远程平台上创建和运行对象的能力。
这被成为远程调用(RMI),它允许一个Java程序将对象分步在多台机器上,江苏java培训认为这种分步能力将帮助开发人员执行一些需要进行大量计算的任务,充分利用计算机资源,提高运行速度。
java 反射 数据类型转换
给你一段属性反射的代码,你自己看着改吧
Field[] fs = userCla.getDeclaredFields();
for(int i = 0 ; i fs.length; i++){
Field f = fs[i];
f.setAccessible(true); //设置些属性是可以访问的
Object val = f.get(bean);//得到此属性的值
System.out.println("name:"+f.getName()+"\t value = "+val);
String type = f.getType().toString();//得到此属性的类型
if (type.endsWith("String")) {
System.out.println(f.getType()+"\t是String");
f.set(bean,"12") ; //给属性设值
}else if(type.endsWith("int") || type.endsWith("Integer")){
System.out.println(f.getType()+"\t是int");
f.set(bean,12) ; //给属性设值
}else{
System.out.println(f.getType()+"\t");
}
}
基本就是getType()之后,根据type的类型来反射
Java反射带参构造创建对象时如何自动转换参数类型
import java.lang.reflect.Constructor;
import java.lang.reflect.InvocationTargetException;
import java.lang.reflect.Method;
public class TestReflection
{
public static void main( String[] args ) throws ClassNotFoundException,
InstantiationException, IllegalAccessException, IllegalArgumentException, SecurityException, InvocationTargetException, NoSuchMethodException
{
String s = "T";
Class? c = Class.forName(s);
Constructor?[] consts = c.getConstructors();
// 定义有参构造
Constructor? consts1 = null;
for( int i = 0; i consts.length; i++ )
{
int paramsLength = consts[i].getParameterAnnotations().length;
if(paramsLength 0)
{
// 判断参数长度取得有参构造
consts1 = consts[i];
}
}
// 得到有参构造参数类型
Class?[] type = consts1.getParameterTypes();
// 实验性数据
Object[] values = { "A", "B", "C" };
// 得到对象
Object obj = c.getConstructor(type).newInstance(values);
System.out.println(obj.getClass().getMethod("getA").invoke(obj));
System.out.println(obj.getClass().getMethod("getB").invoke(obj));
System.out.println(obj.getClass().getMethod("getC").invoke(obj));
}
}
class T
{
private String a;
private String b;
private String c;
public T()
{
System.out.println("T() was loaded...");
}
public T( String a, String b, String c )
{
System.out.println("T(String... s) was loaded...");
this.a = a;
this.b = b;
this.c = c;
}
public String getA()
{
return a;
}
public void setA( String a )
{
this.a = a;
}
public String getB()
{
return b;
}
public void setB( String b )
{
this.b = b;
}
public String getC()
{
return c;
}
public void setC( String c )
{
this.c = c;
}
}
如何用java的反射实现动态强制类型转换~~?
(Cast) 方式本来就是编译时的静态转换,你既然已经在runtime得到TestImpl的具体对象,那就直接使用好了,runtime的时候某个对象是什么类型就已经确定了,不存在类型转换。
java反射类型转换的介绍就聊到这里吧,感谢你花时间阅读本站内容,更多关于java反射的三种方式、java反射类型转换的信息别忘了在本站进行查找喔。