java反射详解(一)_Class类

2019-03-17 09:19|来源: 领悟书生

Class类

Java类用于描述一类事物的共性,该类事物有什么属性,没有什么属性,至于这个属性的值是什么,则是由这个类的实例对象来确定的,不同的实例对象有不同的属性值。Java程序中的各个Java类,它们是否属于同一类事物,是不是可以用一个类来描述这类事物呢?这个类的名字就是Class,要注意与小写class关键字的区别哦。Class类描述了哪些方面的信息呢?类的名字,类的访问属性,类所属于的包名,字段名称的列表、方法名称的列表,等等。学习反射,首先就要明白Class这个类。

Person类代表人,它的实例对象就是张三,李四这样一个个具体的人, Java程序中的各个Java类属于同一类事物,描述这类事物的Java类名就是Class

àPerson

JavaàClass

Class类代表Java类,它的各个实例对象又分别对应什么呢?

对应各个类在内存中的字节码,例如,Person类的字节码,ArrayList类的字节码,等等。

一个类被类加载器加载到内存中,占用一片存储空间,这个空间里面的内容就是类的字节码,不同的类的字节码是不同的,所以它们在内存中的内容是不同的,这一个个的空间可分别用一个个的对象来表示,这些对象显然具有相同的类型,这个类型是什么呢?

如何得到各个字节码对应的实例对象(Class类型)

1.        类名.class,例如,System.class

2.        对象.getClass(),例如,new Date().getClass()

3.        Class.forName("类名"),例如,Class.forName("java.util.Date");

九个预定义Class实例对象:

基本的 Java 类型(booleanbytecharshortintlongfloatdouble)和关键字 void 也表示为 Class 对象

@Test
public void test() throws Exception {
    String str = "abc";
    Class cls1 = str.getClass();
    Class cls2 = String.class;
    Class cls3 = Class.forName("java.lang.String");
    System.out.println(cls1==cls2);
    System.out.println(cls1==cls3);
     
    System.out.println(cls1.isPrimitive());
    System.out.println(int.class.isPrimitive());
    System.out.println(int.class==Integer.class);
    System.out.println(int.class==Integer.TYPE);
    System.out.println(int[].class.isPrimitive());
    System.out.println(int[].class.isArray());
}
true
true
false
true
false
true
false
true

总之,只要是在源程序中出现的类型,都有各自的Class实例对象,例如,int[],void…


本文链接:java反射详解(一)_Class类,由huangyineng原创,转载请注明出处

相关问答

更多
  • 在Java运行时刻,能否知道一个类的属性方法并调用改动之?对于任意一个对象,能否知道他的所属类,并调用他的方法?答案是肯定的。这种动态的获取信息及动态调用方法的机制在Java中称为“反射”(reflection)。 Java反射机制主要提供以下功能: 在运行时判断任意一个对象所属的类; 在运行时构造任意一个类的对象; 在运行时判断任意一个类所具有的成员变量和方法; 在运行时调用任意一个对象的方法。 Reflection 是Java被视为动态(或准动态)语言的一个关键性质。这个机制允许程序在运行时透过Refl ...
  • Reflection(反射) 是 Java 程序开发语言的特征之一,它允许运行中(注意是运行时,而非编译时)的 Java 程序对自身进行检查,或者说“自审”,并能直接操作程序的内部属性。例如,使用它能获得 Java 类中各成员的名称并显示出来,能够通过字符串形式的类名称(包括完整包名)反射性地创建类的实例,能够动态执行类方法等。 JavaBean 是 reflection 的实际应用之一,它能让一些工具可视化的操作软件组件。这些工具通过 reflection 动态的载入并取得 Java 组件(类) 的属性。 ...
  • B.getA()这方法怎么实现的?A是接口,所以直接newInstance是不行的。 你总得有个具体的实现A接口的类吧
  • 来自Java语言规范 方法getClass返回表示对象类的 Class对象。 每个引用类型都存在一个Class对象。 例如,它可用于发现类的完全限定名称,其成员,直接超类以及它实现的任何接口。 由于两个对象都是Reflect1A类型,因此它们都返回相同的Class对象。 你会通过这样做获得相同的对象 Class clazz = Class.forName("com.example.Reflect1A") System.out.println(c1 == clazz); // true ( 虽然并非所 ...
  • Java Reflections API允许您以编程方式对元模型进行操作,即类,方法,字段等。这些是代码的结构信息。 这意味着,当您获得对Field实例的访问权时,它引用由类声明的字段而不是类实例(也称为对象)的字段的实例。 为了使用反射获取字段的值,您必须使用field.get(instance)读取给定实例的值。 在静态字段和方法的情况下,实例是类本身。 但是你不能传递类本身因为.class是一个具有自己的字段和方法的对象,所以field.get(DocumentiDiIdentita.class)将不 ...
  • 是的,你可以做这样的事情: Class parentClass = getClass().getSuperclass(); Field[] fields = parentClass.getDeclaredFields(); for (Field field : fields) { System.out.println("field: " + field.getName()); } Method[] methods = parentClass.getDeclaredMethods(); fo ...
  • 不,通过反射是不可能的,因为使用反射来分析现有代码,而不是改变它。 No, it's not possible through reflection becuase reflection is used to analyze the existing code, not to change it.
  • 两点建议: 确保你给它的完全限定的名称(例如"java.lang.Thread"而不仅仅是"Thread" )。 确保已编译的类文件实际位于类路径中。 Two suggestions: Make sure you're giving it the fully-qualified name (e.g. "java.lang.Thread" and not just "Thread"). Make sure the compiled class file is actually on the classpath ...
  • 您可以使用泛型来声明 Class klass; 那么你将被允许写作 A a = klass.newInstance(); 但是,由于Class.forName没有关于类的类型信息,并且没有声明类型推断,所以您将得到“未经检查的强制转换”警告。 这种方法不仅仅是将第二行的结果向下转换为A类型安全。 You can use Generics to declare Class klass; then you'll be allowed to write A ...