Klasse bedeutet „Klasse“. Sie definiert die Implementierung einer bestimmten Klasse. Ihr Konstruktor ist privat und wird von der JVM (Klassengerät) geladen. um ein Klassenobjekt zu erstellen, das über die Methode getClass() abgerufen werden kann.
Klasse ist eine Klasse, die im Paket java.lang vorhanden ist. Ihr Konstruktor ist privat und das Klassenobjekt wird von der JVM (Klassenlader) erstellt Sie können das Klassenobjekt über die Methode getClass() abrufen.
/* * 私有构造函数,使得只有jvm可以创建该类的对象,这个私有构造函数还可以防止通过默认构造函数创建类对象 */ private Class(ClassLoader loader) { // 初始化final变量ClassLoader classLoader = loader; }
Klassenklasse ist eine Implementierung, die eine bestimmte Klasse in der Java-Sprache definiert. Die Definition einer Klasse umfasst Mitgliedsvariablen, Mitgliedsmethoden, von der Klasse implementierte Schnittstellen und die übergeordnete Klasse der Klasse. Objekte der Class-Klasse werden verwendet, um Klassen und Schnittstellen in der aktuell ausgeführten Java-Anwendung darzustellen. Beispiel: Jedes Array gehört zu einem Klassenobjekt und alle Arrays mit demselben Elementtyp und derselben Dimension teilen sich ein Klassenobjekt. Grundlegende Java-Typen (boolean, byte, char, short, int, long, float und double) und void-Typen können auch als Klassenobjekte dargestellt werden.
Klassenobjekt, über das wir die Attribute, Methoden usw. der erstellten Klasse abrufen können.
Die Rolle der Klassenklasse
(1) Ermitteln Sie die Art der Attribute in der Klasse
( 2) Den Namen des Attributs in der Klasse abrufen
(3) Die Methode der Klasse abrufen
(4) Die Basisklasse der Klasse abrufen usw.
(5) Basierend auf dem oben Gesagten können Sie es verwenden, um die Reflexion zu vervollständigen
Hauptmethode der Klasse
1 forName-Methode
Geben Sie ein Vollständiger Pfadname der Klasse, die geladen werden muss, und das Klassenobjekt der Klasse abrufen.
2.newInstance-Methode
public T newInstance() throws InstantiationException, IllegalAccessException { if (System.getSecurityManager() != null) { checkMemberAccess(Member.PUBLIC, Reflection.getCallerClass(), false); } // NOTE: 下面的编码可能不是严格符合当前的java内存模型 // 寻找构造器 if (cachedConstructor == null) { if (this == Class.class) { throw new IllegalAccessException( "Can not call newInstance() on the Class for java.lang.Class" ); } try { Class<?>[] empty = {}; //获取无参构造器,如果没有就抛出异常,说明这个方法只适用于有无参构造函数的类 final Constructor<T> c = getConstructor0(empty, Member.DECLARED); // 设置构造器允许访问 java.security.AccessController.doPrivileged( new java.security.PrivilegedAction<Void>() { public Void run() { c.setAccessible(true); return null; } }); cachedConstructor = c; } catch (NoSuchMethodException e) { throw (InstantiationException) new InstantiationException(getName()).initCause(e); } } Constructor<T> tmpConstructor = cachedConstructor; // 安全检查 int modifiers = tmpConstructor.getModifiers(); if (!Reflection.quickCheckMemberAccess(this, modifiers)) { Class<?> caller = Reflection.getCallerClass(); if (newInstanceCallerCache != caller) { Reflection.ensureMemberAccess(caller, this, null, modifiers); newInstanceCallerCache = caller; } } // 执行无参构造函数创建实例对象 try { return tmpConstructor.newInstance((Object[])null); } catch (InvocationTargetException e) { Unsafe.getUnsafe().throwException(e.getTargetException()); // Not reached return null; } }
3.isInstance (native Methode)
Verwendet um zu bestimmen, ob der Eingabeparameter die Implementierungsklasse des aktuellen Klassenobjekts (Unterklasse) ist
public class TestInfo { static { System.out.println("我是谁"); } public TestInfo(){ System.out.println("我是构造函数"); } public String test="测试属性"; public static void main(String[] args) { TestClass info=new TestClass(); //返回结果是true因为info是子类的对象System.out.println(TestInfo.class.isInstance(info)); } public static class TestClass extends TestInfo{ }}
4.getName, getTypeName, getCanonicalName, getSimpleName
public static void main(String[] args) { System.out.println(TestClass.class.getTypeName()); System.out.println(TestClass.class.getCanonicalName()); System.out.println(TestClass.class.getSimpleName()); System.out.println(TestClass.class.getName()); System.out.println("-------------------------------------------------------"); System.out.println(TestClass[].class.getTypeName()); System.out.println(TestClass[].class.getCanonicalName()); System.out.println(TestClass[].class.getSimpleName()); System.out.println(TestClass[].class.getName()); } public static abstract class TestClass<T extends TestInfo, String> extends TestInfo implements Aware, Comparable<Integer> { public abstract void test(); }
Ausgabeergebnisse
com.hikvision.test.abc.TestInfo$TestClass com.hikvision.test.abc.TestInfo.TestClass TestClass com.hikvision.test.abc.TestInfo$TestClass ------------------------------------------------------- com.hikvision.test.abc.TestInfo$TestClass[] com.hikvision.test.abc.TestInfo.TestClass[] TestClass[] [Lcom.hikvision.test.abc.TestInfo$TestClass;
5.getClassLoader
Ruft den Klassenlader der aktuellen Klasse ab
6.getTypeParameters
Ruft das generische Parameterarray in der generischen Klasse ab.
7.getSuperclass und getGenericSuperclass
beide erhalten Informationen zur übergeordneten Klasse, letztere bringt jedoch generische Parameter
8.getInterfaces und getGenericInterfaces
Ruft die Schnittstelle ab Array, das vom aktuellen Klassenobjekt implementiert wird, aber letzteres bringt die generischen Parameter der Schnittstelle mit, wie z. B.
public static void main(String[] args) { System.out.println(TestClass.class.getInterfaces()[1]); } public static abstract class TestClass<T extends TestInfo,String> extends TestInfo implements Aware,BeanFactory { public abstract void test(); }
Ausgabeergebnis
interface org.springframework.beans.factory.BeanFactory java.lang.Comparable<java.lang.Integer>
9.isAssignableFrom(native method)
Diese Methode ist ziemlich unmenschlich. Die Eingabeparameter in Klammern repräsentieren die übergeordnete Klasse des aktuellen Klassenobjekts oder desselben Objekts.
//这样返回的是false System.out.println(TestClass.class.isAssignableFrom(TestInfo.class));
10.isInterface (native Methode)
Bestimmen Sie, ob es sich um eine Schnittstelle handelt
11.isArray (native Methode)
ob es sich um ein Array handelt
12.isPrimitive (native Methode)
wird verwendet, um zu bestimmen, ob dieses Klassenobjekt ein Basistyp ist, wie z. B. int, byte, char usw.
13. isAnnotation
bestimmt, ob das Klassenobjekt eine Annotation ist
14.getComponentType
Wenn das aktuelle Klassenobjekt ein Array ist, holen Sie sich den Elementtyp im Array
15.getModifiers
Rufen Sie die Attribute ab Oder den Aufzählungswert, der dem Modifikator vor der Methode entspricht
16.getDeclaringClass
Rufen Sie die Klasse ab, zu der die Methode gehört oder Attribut gehört, oder die Klasse abrufen, von der das aktuelle Klassenobjekt erbt
17 .getSimpleName
Der Klassenname des Klassenobjekts
18.getClasses, getDeclaredClasses
(1) Holen Sie sich die öffentlich geänderte interne Klasse im Class-Objekt
(2 ) Holen Sie sich die interne Klasse im Class-Objekt, geerbte Mitglieder sind nicht enthalten
19.getFields , getField, getDeclaredFields
(1) Holen Sie sich das öffentliche geänderte Attributfeld
(2) Suchen Sie die entsprechende Attributdomäne
basierend auf dem eingegebenen Attributnamen (3) Holen Sie sich das Attributdomäne im Klassenobjekt
20.getMethods, getMethod, getDeclaredMethods
( 1) Holen Sie sich die öffentliche geänderte Methode
(2) Suchen Sie die entsprechende Methode
entsprechend dem Namen der Eingabemethode und dem Parametertyp (3) Holen Sie sich die Methode im Klassenobjekt
21.getConstructors, getConstructor, getDeclaredConstructors
(1) Holen Sie sich den öffentlichen modifizierten Konstruktor
(2) Suchen Sie den entsprechenden Konstruktor
(3) Rufen Sie den Konstruktor im Klassenobjekt abDas obige ist der detaillierte Inhalt vonWas bedeutet Klasse in Java?. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!