- 浏览: 127972 次
- 性别:
- 来自: 广州
文章分类
最新评论
-
hanyuanbo:
多谢啦不过你这里有关于字符串的连接机制么?比如:String ...
栈(stack)与堆(heap)区别以及Java的string变量赋值的内部工作机制(精典转载贴) -
only_java:
不错不错,但是好像没有关于字符流的介绍哦?
[转]Java IO 技术之基本流类 ~~~~~~~~ (图+讲解+代码) 好好看 有好处 -
lvwz2008:
比较简单,学习了也受益不少!
栈(stack)与堆(heap)区别以及Java的string变量赋值的内部工作机制(精典转载贴) -
306781704:
看了你写的东西,很不错,基础的很详细
META元素使用详解 -
yihengliu:
总结的完全,有大帮助!
JSP内置对象详解1
Java Reflection API 运用示例<o:p></o:p>
图5示范图4提过的每一个Reflection API,及其执行结果。程序中出现的tName()是个辅助函数,可将其第一自变量所代表的“Java class完整路径字符串”剥除路径部分,留下class名称,储存到第二自变量所代表的一个hashtable去并返回(如果第二自变量为null,就不储存而只是返回)。<o:p></o:p>
<o:p> </o:p>
#001 Class c = null;<o:p></o:p>
#<st1:chmetcnv w:st="on" tcsc="0" numbertype="1" negative="False" hasspace="True" sourcevalue="2" unitname="C">002 c</st1:chmetcnv> = Class.forName(args[0]);<o:p></o:p>
#003<o:p></o:p>
#004 Package p;<o:p></o:p>
#005 p = c.getPackage();<o:p></o:p>
#006<o:p></o:p>
#007 if (p != null)<o:p></o:p>
#008 System.out.println("package "+p.getName()+";");<o:p></o:p>
<o:p> </o:p>
执行结果(例):<o:p></o:p>
package java.util;<o:p></o:p>
图5-1:找出class 隶属的package。其中的c将继续沿用于以下各程序片段。<o:p></o:p>
<o:p> </o:p>
#001 ff = c.getDeclaredFields();<o:p></o:p>
#002 for (int i = 0; i < ff.length; i++)<o:p></o:p>
#003 x = tName(ff[i].getType().getName(), classRef);<o:p></o:p>
#004<o:p></o:p>
#005 cn = c.getDeclaredConstructors();<o:p></o:p>
#006 for (int i = 0; i < cn.length; i++) {<o:p></o:p>
#007 Class cx[] = cn[i].getParameterTypes();<o:p></o:p>
#008 for (int j = 0; j < cx.length; j++)<o:p></o:p>
#009 x = tName(cx[j].getName(), classRef);<o:p></o:p>
#010 }<o:p></o:p>
#011<o:p></o:p>
#<st1:chmetcnv w:st="on" tcsc="0" numbertype="1" negative="False" hasspace="True" sourcevalue="12" unitname="mm">012 mm</st1:chmetcnv> = c.getDeclaredMethods();<o:p></o:p>
#013 for (int i = 0; i < mm.length; i++) {<o:p></o:p>
#014 x = tName(mm[i].getReturnType().getName(), classRef);<o:p></o:p>
#015 Class cx[] = mm[i].getParameterTypes();<o:p></o:p>
#016 for (int j = 0; j < cx.length; j++)<o:p></o:p>
#017 x = tName(cx[j].getName(), classRef);<o:p></o:p>
#018 }<o:p></o:p>
#019 classRef.remove(c.getName()); //不必记录自己(不需import 自己)<o:p></o:p>
<o:p> </o:p>
执行结果(例):<o:p></o:p>
import java.util.ListIterator;<o:p></o:p>
import java.lang.Object;<o:p></o:p>
import java.util.LinkedList$Entry;<o:p></o:p>
import java.util.Collection;<o:p></o:p>
import java.io.ObjectOutputStream;<o:p></o:p>
import java.io.ObjectInputStream;<o:p></o:p>
图5-2:找出导入的classes,动作细节详见内文说明。<o:p></o:p>
<o:p> </o:p>
#001 int mod = c.getModifiers();<o:p></o:p>
#002 System.out.print(Modifier.toString(mod)); //整个modifier<o:p></o:p>
#003<o:p></o:p>
#004 if (Modifier.isInterface(mod))<o:p></o:p>
#005 System.out.print(" "); //关键词 "interface" 已含于modifier<o:p></o:p>
#006 else<o:p></o:p>
#007 System.out.print(" class "); //关键词 "class"<o:p></o:p>
#008 System.out.print(tName(c.getName(), null)); //class 名称<o:p></o:p>
<o:p> </o:p>
执行结果(例):<o:p></o:p>
public class LinkedList<o:p></o:p>
图5-3:找出class或interface 的名称,及其属性(modifiers)。<o:p></o:p>
<o:p> </o:p>
#001 TypeVariable<Class>[] tv;<o:p></o:p>
#002 tv = c.getTypeParameters(); //warning: unchecked conversion<o:p></o:p>
#003 for (int i = 0; i < tv.length; i++) {<o:p></o:p>
#004 x = tName(tv[i].getName(), null); //例如 E,K,V...<o:p></o:p>
#005 if (i == 0) //第一个<o:p></o:p>
#006 System.out.print("<" + x);<o:p></o:p>
#007 else //非第一个<o:p></o:p>
#008 System.out.print("," + x);<o:p></o:p>
#009 if (i == tv.length-1) //最后一个<o:p></o:p>
#010 System.out.println(">");<o:p></o:p>
#011 }<o:p></o:p>
<o:p> </o:p>
执行结果(例):<o:p></o:p>
public abstract interface Map<K,V><o:p></o:p>
或 public class LinkedList<E><o:p></o:p>
图5-4:找出parameterized types 的名称<o:p></o:p>
<o:p> </o:p>
#001 Class supClass;<o:p></o:p>
#002 supClass = c.getSuperclass();<o:p></o:p>
#003 if (supClass != null) //如果有super class<o:p></o:p>
#004 System.out.print(" extends" +<o:p></o:p>
#005 tName(supClass.getName(),classRef));<o:p></o:p>
<o:p> </o:p>
执行结果(例):<o:p></o:p>
public class LinkedList<E><o:p></o:p>
extends AbstractSequentialList,<o:p></o:p>
图5-5:找出base class。执行结果多出一个不该有的逗号于尾端。此非本处重点,为简化计,不多做处理。<o:p></o:p>
<o:p> </o:p>
#001 Class cc[];<o:p></o:p>
#002 Class ctmp;<o:p></o:p>
#003 //找出所有被实现的interfaces<o:p></o:p>
#004 cc = c.getInterfaces();<o:p></o:p>
#005 if (cc.length != 0)<o:p></o:p>
#006 System.out.print(", \r\n" + " implements "); //关键词<o:p></o:p>
#007 for (Class cite : cc) //JDK1.5 新式循环写法<o:p></o:p>
#008 System.out.print(tName(cite.getName(), null)+", ");<o:p></o:p>
<o:p> </o:p>
执行结果(例):<o:p></o:p>
public class LinkedList<E><o:p></o:p>
extends AbstractSequentialList,<o:p></o:p>
implements List, Queue, Cloneable, Serializable,<o:p></o:p>
图5-6:找出implemented interfaces。执行结果多出一个不该有的逗号于尾端。此非本处重点,为简化计,不多做处理。<o:p></o:p>
发表评论
-
中文乱码问题的解决方法
2007-11-05 22:46 2066tomcat下中文的彻底解决[转] http://blog ... -
候捷谈Java反射机制(6)
2007-11-05 22:44 1454Java 源码改动办法<o:p></o:p ... -
候捷谈Java反射机制(5)
2007-11-05 22:43 1109运行时生成instances<o:p></o ... -
候捷谈Java反射机制(4)
2007-11-05 22:42 1088#001 cc = c.getDeclaredClasses ... -
候捷谈Java反射机制(2)
2007-11-05 22:39 1016Java classes 组成分析<o:p>&l ... -
候捷谈Java反射机制(1)
2007-11-05 22:28 1609关于本文:<o:p></o:p> 读者 ... -
J2SE API读取Properties文件六种方法
2007-11-05 22:23 10271。使用java.util.Properti ... -
Java 调用存储过程
2007-11-05 22:21 883本文阐述了怎 ... -
JavaMail API细节详细解析大全
2007-11-05 22:16 1120一、JavaMail API简介 JavaMail API ... -
JAVA中正则表达式应用
2007-11-05 22:12 8291.简介: java.util.regex ... -
Java正则表达式详解
2007-11-05 22:08 803如果你曾经用过Perl或任何其他内建正则表达 ... -
JDBC 4.0 API
2007-11-05 21:55 1027???? -
JDBC 3.0 API (扩展部分)
2007-11-05 21:54 1230Ø ConnectionPoo ... -
JDBC 2.0 API
2007-11-05 17:19 975JDBC 2.0 API被划 ... -
开发基于JNDI的应用程序3
2007-11-05 16:18 1791JNDI 的DNS 服务提供程序 DNS服务提供程序使得基于 ... -
开发基于JNDI的应用程序2
2007-11-05 16:14 1369示例代码 2 Resolve2.java ... -
开发基于JNDI的应用程序1
2007-11-05 16:06 1065Java命名和目录接口(Java Naming and ... -
struts+spring+hibernate的web应用(4.6)
2007-10-25 11:35 934product_success.jsp页面代码: ... -
struts+spring+hibernate的web应用(4.5)
2007-10-25 11:32 1109addproduct.jsp页面代码: &l ... -
struts+spring+hibernate的web应用(4.4)
2007-10-25 11:11 1008接着就是写资源文件了。 在com.game.resource ...
相关推荐
Java反射机制是Java编程语言中的一个重要特性,它允许程序在运行时获取和操作任何已知名称的类的内部信息。这一机制使得Java具备了一定的动态性,虽然在传统的分类中Java被视为静态类型语言。通过反射,开发者可以在...
7. **反射机制**:深入理解Java反射的概念,如何在运行时动态访问类、接口、方法和构造器。 8. **设计模式**:讲解常用的设计模式,如单例、工厂、观察者、装饰者、代理等,以及如何在实际开发中应用。 9. **JVM...
这篇《候捷谈Java反射机制》的文章应该深入探讨了这一主题。 反射的核心概念主要包括Class类、Constructor类、Method类和Field类。以下是对这些关键知识点的详细说明: 1. **Class类**:在Java中,每个类都有一个...
- **异常处理**:详细讲解Java中的异常处理机制,包括异常的抛出、捕获及处理策略,帮助开发者编写健壮的应用程序。 - **泛型与集合框架**:重点介绍了Java泛型的概念及其在集合框架中的应用,使开发者能够写出类型...
7. **反射机制**:利用反射动态获取类的信息,创建对象,调用方法,修改字段值,了解Class类和Method类的使用。 8. **设计模式**:常见的设计模式如工厂模式、单例模式、观察者模式、装饰者模式等,理解其应用场景...
8. **反射与动态代理**:Java的反射机制能让我们在运行时检查类的信息并操作对象,动态代理则能在运行时创建具有特定接口的代理类,这对于AOP(面向切面编程)和插件式系统很有用。 9. **Java EE基础**:虽然不是...
2. **Java技术**:精通Java核心技术,包括反射、集合、网络编程和IO流的使用。 3. **Web应用开发**:熟练运用jsp、servlet、JSTL/EL、dom4j和JDBC,具备Struts2、Spring、Hibernate等主流框架的实践经验。 4. **...