时间:2013-09-20 09:43:27 作者:啤酒 阅读:16777215
一、类型识别的两种方式:
首先了解一下“运行时类型识别”(Run-time Type Identification, RTTI)主要有两种方式,
第一种:是我们在一次编译时和运行时已经知道了所有的类型。
第二种:是我们在整项目分模块的编译,在运行时可以对新加入的模块进行动态的编译。(在动态编译模块之前还不知道被编译code的类型。) 这就是下面要接受的,功能强大的“反射”机制。
二、认识“Class对象”:
要理解RTTI(运行时类型识别)在Java中的工作原理,首先必须知道类型信息在运行时是如何表示的,这项工作是由“Class对象”完成的,它包含了与类有关的信息。
类是程序的重要组成部分(类的属性,方法以及它的一些特性,在这里我就不做赘述了。),每个类都有一个Class对象,每当编写并编译了一个新类就会产生一个Class对象,它被保存在一个与你所创建的新类同名的.class文件中。那么在程序运行时,当我们想生成这个类的对象时(实例化这个类),运行这个程序的Java虚拟机(JVM)就会这样做:
首先会从加载所创新类的.class文件,
然后确认这个新类的Class对象是否已经加载,如果尚未加载,JVM就会根据类名查找.class文件,并将其载入,一旦这个类的Class对象被载入内存,它就被用来创建这个类的所有对象。
一般的RTTI形式包括三种:
1.传统的类型转换。如“(Apple)Fruit”,由RTTI确保类型转换的正确性,如果执行了一个错误的类型转换,就会抛出一个ClassCastException异常。
2.通过Class对象来获取对象的类型。如
[code="java"] Class c = Class.forName(“Apple”);
Object o = c.newInstance();
3.通过关键字instanceof或Class.isInstance()方法来确定对象是否属于某个特定类型的实例,准确的说,应该是instanceof / Class.isInstance()可以用来确定对象是否属于某个特定类及其所有基类的实例,这和equals() / ==不一样,它们用来比较两个对象是否属于同一个类的实例,没有考虑继承关系。[enxtpage]
三、反射
如果不知道某个对象的类型,可以通过RTTI来获取,但前提是这个类型在编译时必须已知,这样才能使用RTTI来识别。即在编译时,编译器必须知道所有通过RTTI来处理的类。
使用反射机制可以不受这个限制,它主要应用于两种情况:
第一种情况,是“基于构件的编程”这种编程方式中,将使用某种基于快速应用开发(RAD)的应用构建工具来构建项目。这是现在最常见的可视化编程方法,通过代表不同组件的图标拖动到图板上,然后设置”构件“(组件)的属性值来配置它们来创建程序。要做到这种配置编程,就必须要求构件都是可实例化的,并且要暴露其部分信息,使得程序员可以读取和设置构件的值和状态。当处理GUI时间的构件时还必须暴露相关方法的事件处理细节,以便RAD环境帮助程序员覆盖这些处理事件的方法。在这里,就要用到反射的机制来检查可用的方法并返回方法实体对象。Java通过JavaBeans提供了基于构件的编程架构。
第二种情况,在运行时获取类的信息的另外一个动机,就是希望能够提供在跨网络的远程平台上创建和运行对象的能力。这被成为远程调用(RMI),它允许一个Java程序将对象分步在多台机器上,这种分步能力将帮助开发人员执行一些需要进行大量计算的任务,充分利用计算机资源,提高运行速度。
Class类支持反射,是在java.lang.reflect中包含了Field/Method/Constructor类,每个类都实现了Member接口。这些类型的对象都是由JVM在运行时创建的,用来表示未知类里对应的成员。如可以用Constructor类创建新的对象,用get()和set()方法读取和修改与Field对象关联的字段,用invoke()方法调用与Method对象关联的方法。同时,还可以调用getFields()、getMethods()、getConstructors()等方法来返回表示字段、方法以及构造器的对象数组。这样,未知的对象的类信息在运行时就能被完全确定下来,而在编译时不需要知道任何信息。
另外,RTTI有时能解决效率问题。当程序中使用多态给程序的运行带来负担的时候,可以使用RTTI编写一段代码来提高效率。
BlueJ For Mac V2.1.6 5.7MB
下载BlueJ For Mac V2.1.6 5.7MB
下载BlueJ For Mac V2.1.6 5.7MB
下载BlueJ For Mac V2.1.6 5.7MB
下载BlueJ For Mac V2.1.6 5.7MB
下载有很多用户在使用最新的OSX 10.11系统时会发现java SE 6不兼容的问题,其实要解决 这个问题比较简单,用户需要下载安装最新的Java SE 8就能完美的解决这个问题,下面小编详细的为大家解说一下具体的解决办法。
16777215一、类型识别的两种方式:
16777215在现实工作中,我们常常需要保存一些系统配置信息,大家一般都会选择配置文件来完成,本文根据笔者工作中用到的读取配置文件的方法小小总结一下,主要叙述的是spring读取配置文件的方法。
167772151. 从sun主页下载JDK for Linux版本。这里下载的是jdk-6u6-linux-i586.bin.
16777215以前使用JPA的实现是toplink,现在改为hibernate,所以要修改persistence.xml文件,两者的配置有一些不一样,并且在EE环境下面和SE的环境下面也有不一样,还有一点,那就是当persistence.xml里面有些格式出错的时候,虽然出错的不是我们需要的那个单元,但也会使得整个persistence.xml报废。
16777215Java:jdk-1_5_0_06-windows-i586-p.exe
167772151.在要调试的过程上单击test,如下图所示:
16777215Fedora 的Java路径通常为/usr/bin/java,而且是GNU的Java版本,对很多软件来说都不适合。
16777215大家应该都会注意到Java软件安装文件夹的编号比如MIDlet20005,MIDlet20032,MIDlet20055等等,装过越多,编号会越来越大,即使你已经卸载掉!造成编号的不连续,中间很多编号都空缺!只装了10个不到的Java,编号却到了100都有可能。 解决空缺编号的方法如下:在mmc/mmca1/.system/Java/JAMinfo下有个maxsuiteid_card1的文件和一个index_card1文件!用ezxlocaleditor打开maxsuiteid_card1文件!里面看到的就是最近安装的Java的编号。 比如20026,因此你下次Java软件安装的Java的编号将是20027,如果你发现mmc/mmca1/.system/Java/DownloadApps下的文件夹编号20005~20016都是空缺的!而你要想让下一次安装的Java编号补到20005上!则将maxsuiteid_card1文件里的数值改为20004. 但要注意的是如果中间比如20010编号已被占用,需手动改回!否则旧的将会被新装的覆盖。 另外在你替换Java图标或单独绿色时想在那么多编号文件夹里找到对应的程序难免头痛!这时index_card1文件就派上用场了!里面记录的是Java的安装信息,你可以方便地找到编号与相应程序的对应关系!通过修改编号后紧接着的安装软件的名称,可以实现同一个Java程序的多个安装,而不会提示更新!
16777215