Introduction détaillée au mécanisme de réflexion Java
Nov 25, 2019 pm 02:48 PMCet article de la rubrique Introduction à la programmation Java présente en détail le mécanisme de réflexion en Java, dans l'espoir d'aider les étudiants qui ne comprennent pas ce mécanisme. Le mécanisme de
réflexion Java
est en cours d'exécution Pour n'importe quelle classe, il peut conna?tre toutes les propriétés et méthodes de cette classe (y compris les privées) ; object , peut appeler n'importe laquelle de ses méthodes et propriétés ; cette fonction d'obtention dynamique d'informations et d'appel dynamique de méthodes objet est appelée mécanisme de réflexion de Java.
Objectif?:
Déterminer la classe à laquelle appartient tout objet au moment de l'exécution.
Construisez un objet de n'importe quelle classe au moment de l'exécution.
Jugez les variables membres et les méthodes de n'importe quelle classe au moment de l'exécution.
Appelez la méthode de n’importe quel objet au moment de l’exécution.
Générer un proxy dynamique.
Classes liées à la réflexion
classe de classe
obtenues dans le programme Java Objets de classe ont généralement les trois méthodes suivantes?:
1. Utilisez la méthode statique forName (String clazzName) de la classe Class. Cette méthode nécessite de transmettre un paramètre cha?ne dont la valeur est le nom complet d'une classe (le nom complet du package doit être ajouté).
2. Appelez l'attribut de classe d'une certaine classe pour obtenir l'objet Class correspondant à la classe.
3. Appelez la méthode getClass() d'un objet. Cette méthode est une méthode de la classe java.lang.Object.
Champ
Field[] allFields = class2.getDeclaredFields();//獲取class對象的所有屬性 Field[] publicFields = class2.getFields();//獲取class對象的public屬性 Field ageField = class2.getDeclaredField("age");//獲取class指定屬性,可以獲得私有屬性 Field desField = class2.getField("des");//獲取class指定的public屬性
Méthode
Method[] methods = class2.getDeclaredMethods();//獲取class對象的所有聲明方法 Method[] allMethods = class2.getMethods();//獲取class對象的所有public方法 包括父類的方法 Method method = class2.getMethod("info", String.class);//返回次Class對象對應(yīng)類的、帶指定形參列表的public方法 Method declaredMethod = class2.getDeclaredMethod("info", String.class);//返回次Class對象對應(yīng)類的、 帶指定形參列表的方法
Constructeur
Constructor<?>[] allConstructors = class2.getDeclaredConstructors();//獲取class對象的所有聲明構(gòu)造函數(shù) Constructor<?>[] publicConstructors = class2.getConstructors();//獲取class對象public構(gòu)造函數(shù) Constructor<?> constructor = class2.getDeclaredConstructor(String.class);//獲取指定聲明構(gòu)造函數(shù) Constructor publicConstructor = class2.getConstructor(String.class);//獲取指定聲明的public構(gòu)造函數(shù)
Générer des objets d'instance par réflexion
1 Utilisez la méthode newInstance() de l'objet Class pour créer une instance de la classe correspondante de l'objet Class. Cette méthode nécessite que la classe correspondante de l'objet Class ait un constructeur par défaut, et lorsque la méthode newInstance() est exécutée, le constructeur par défaut est en fait utilisé pour créer une instance de la classe.
2. Utilisez d'abord l'objet Class pour obtenir l'objet Constructor spécifié, puis appelez la méthode newInstance() de l'objet Constructor pour créer une instance de la classe correspondante de l'objet Class. De cette fa?on, vous pouvez choisir d'utiliser un constructeur spécifié pour créer l'instance.
Appeler la méthode
1. Obtenez la méthode spécifiée via la méthode getMethods() ou la méthode getMethod() de l'objet Class et renvoyez le tableau ou l'objet Method.
2. Appelez la méthode Object Invoke(Object obj, Object… args) dans l'objet Method. Le premier paramètre correspond à l'objet instance appelant la méthode, et le deuxième paramètre correspond aux paramètres de la méthode.
Exemple de code?:
Qu'est-ce que la réflexion??
package am; import java.lang.reflect.Constructor; import java.lang.reflect.Field; import java.lang.reflect.Method; import java.util.Arrays; import javax.activation.FileDataSource; /** * 反射是什么: * java中的反射:就是在類的加載過程中,發(fā)現(xiàn)類的屬性和方法構(gòu)造方法等信息??梢垣@得類的屬性值,可以調(diào)用類的方法。 * * * 反射獲得類的對象。 * */ public class Demo01 { public static void main(String[] args) throws Exception{ // 通過反射,獲取類的對象。 Object obj = create("am.Foo");; Foo foo = (Foo)obj; System.out.println(foo.a); double dou = foo.show(12, "hello"); System.out.println(dou); System.out.println("======================================"); // 獲得類的屬性 showField(obj); System.out.println("======================================"); double a = (double)getFieldValue(obj, "b"); System.out.println(a); System.out.println("========================================"); // 通過反射調(diào)用方法。 Object ob = getMethodValue(obj,"show",new Class[]{int.class,String.class},new Object[]{23,"abc"}); double douValue = (double)ob; System.out.println(douValue); } //通過反射調(diào)用方法,哪個對象,什么名稱,參數(shù)類型,參數(shù)值 public static Object getMethodValue(Object obj,String method,Class[] paramType,Object[] param) throws Exception{ Class cla = obj.getClass(); Method me = cla.getDeclaredMethod(method, paramType); Object o = me.invoke(obj, param); return o; } // 獲取類的屬性值: public static Object getFieldValue(Object obj,String name)throws Exception{ Class cla = obj.getClass();// 獲取字節(jié)碼對象。 Field field = cla.getDeclaredField(name);// 通過屬性的名稱。獲取當(dāng)前屬性。 Object result = field.get(obj); return result; } // 通過反射,可以獲得類的屬性信息以及方法信息。 public static void showField(Object obj){ // java中對屬性類。 Field 方法類:Method Class cla = obj.getClass(); System.out.println("獲取類名:"+cla.getName()); System.out.println("======================================"); // 獲取類的屬性: Field[] fields = cla.getDeclaredFields();// 獲取公開的屬性。 for(Field field : fields){ System.out.println("獲取類的屬性類型"+field.getType()); System.out.println("獲取類的屬性名稱:"+field.getName()); } System.out.println("======================================"); // 獲取類的方法。 Method[] methods = cla.getDeclaredMethods(); for(Method method : methods){ System.out.println("獲取方法的返回值類型:"+method.getReturnType()); System.out.println("獲取方法名稱:"+method.getName()); System.out.println("獲取方法的參數(shù)類型。"+Arrays.toString(method.getParameterTypes())); } System.out.println("======================================="); // 獲取類的構(gòu)造方法: Constructor[] cons = cla.getDeclaredConstructors(); for(Constructor con : cons){ System.out.println("構(gòu)造方法的名字:"+con.getName()); System.out.println("構(gòu)造方法參數(shù)類型:"+Arrays.toString(con.getParameterTypes())); } } // 如何反射類的實例。 public static Object create(String name) throws Exception{ // 反射的方法。Class.forName(); Class cla = Class.forName(name); // 如何獲得Object類型對象。 Object obj = cla.newInstance(); return obj; } } // 模擬類。 class Foo{ int a = 10; double b = 20; public double show(int p,String str){ System.out.println("調(diào)用方法傳入的值是:"+str); return a+b+p; } public Foo(){ } public Foo(int a,int b){ } }
Autres recommandations de vidéos d'apprentissage connexes?: tutoriel vidéo Java
Ce qui précède est le contenu détaillé de. pour plus d'informations, suivez d'autres articles connexes sur le site Web de PHP en chinois!

Outils d'IA chauds

Undress AI Tool
Images de déshabillage gratuites

Undresser.AI Undress
Application basée sur l'IA pour créer des photos de nu réalistes

AI Clothes Remover
Outil d'IA en ligne pour supprimer les vêtements des photos.

Clothoff.io
Dissolvant de vêtements AI

Video Face Swap
échangez les visages dans n'importe quelle vidéo sans effort grace à notre outil d'échange de visage AI entièrement gratuit?!

Article chaud

Outils chauds

Bloc-notes++7.3.1
éditeur de code facile à utiliser et gratuit

SublimeText3 version chinoise
Version chinoise, très simple à utiliser

Envoyer Studio 13.0.1
Puissant environnement de développement intégré PHP

Dreamweaver CS6
Outils de développement Web visuel

SublimeText3 version Mac
Logiciel d'édition de code au niveau de Dieu (SublimeText3)

Pour gérer correctement les transactions JDBC, vous devez d'abord désactiver le mode de validation automatique, puis effectuer plusieurs opérations, et enfin vous engager ou randonner en fonction des résultats; 1. Appelez Conn.SetAutoCommit (false) pour démarrer la transaction; 2. Exécuter plusieurs opérations SQL, telles que l'insertion et la mise à jour; 3. Appelez Conn.Commit () Si toutes les opérations sont réussies, et appelez Conn.Rollback () Si une exception se produit pour garantir la cohérence des données; Dans le même temps, les ressources TRY-With doivent être utilisées pour gérer les ressources, gérer correctement les exceptions et cl?turer les connexions pour éviter la fuite de connexion; De plus, il est recommandé d'utiliser des pools de connexion et de définir des points de sauvegarde pour réaliser un retour en arrière partiel, et de maintenir les transactions aussi courtes que possible pour améliorer les performances.

Pré-formancetartuptimemoryusage, quarkusandmicronautleadduetocompile-timeprocessingandgraalvsupport, withquarkusofperforming lightbetterine scénarios.

HTTP Log Middleware dans GO peut enregistrer les méthodes de demande, les chemins de requête, la propriété intellectuelle du client et le temps qui prend du temps. 1. Utilisez http.handlerfunc pour envelopper le processeur, 2. Enregistrez l'heure de début et l'heure de fin avant et après l'appel Suivant.Servehttp, 3. Obtenez le vrai client IP via R.RemoteAddr et X-Forwared-For Headers, 4. Utilisez le log.printf aux journaux de demande de sortie, 5. L'exemple de code complet a été vérifié pour s'exécuter et convient au démarrage d'un projet petit et moyen. Les suggestions d'extension incluent la capture des codes d'état, la prise en charge des journaux JSON et le suivi des ID de demande.

La collecte des ordures de Java (GC) est un mécanisme qui gère automatiquement la mémoire, ce qui réduit le risque de fuite de mémoire en récupérant des objets inaccessibles. 1. GC juge l'accessibilité de l'objet de l'objet racine (tel que les variables de pile, les threads actifs, les champs statiques, etc.), et les objets inaccessibles sont marqués comme des ordures. 2. Sur la base de l'algorithme de compensation de marque, marquez tous les objets accessibles et effacez des objets non marqués. 3. Adopter une stratégie de collecte générationnelle: la nouvelle génération (Eden, S0, S1) exécute fréquemment MinorGC; Les personnes agées fonctionnent moins, mais prend plus de temps pour effectuer MajorGC; Metaspace Stores Metadata de classe. 4. JVM fournit une variété de périphériques GC: SerialGC convient aux petites applications; Le parallelGC améliore le débit; CMS réduit

Le choix du bon type HTMLinput peut améliorer la précision des données, améliorer l'expérience utilisateur et améliorer la convivialité. 1. Sélectionnez les types d'entrée correspondants en fonction du type de données, tels que le texte, le courrier électronique, le tel, le numéro et la date, qui peuvent vérifier automatiquement la somme de la somme et l'adaptation au clavier; 2. Utilisez HTML5 pour ajouter de nouveaux types tels que l'URL, la couleur, la plage et la recherche, qui peuvent fournir une méthode d'interaction plus intuitive; 3. Utilisez l'espace réservé et les attributs requis pour améliorer l'efficacité et la précision du remplissage des formulaires, mais il convient de noter que l'espace réservé ne peut pas remplacer l'étiquette.

GradleisthebetterChoiceFormostNewProjectsDuetOtsSuperiorflexibility, Performance et ModerNtoolingSupport.1.gradle’sgroovy / kotlindslismoreConcis

Le report est utilisé pour effectuer des opérations spécifiées avant le retour de la fonction, telles que les ressources de nettoyage; Les paramètres sont évalués immédiatement lorsqu'ils sont reportés et les fonctions sont exécutées dans l'ordre de la dernière entrée (LIFO); 1. Plusieurs éleveurs sont exécutés dans l'ordre inverse des déclarations; 2. Communément utilisé pour le nettoyage sécurisé tel que la fermeture des fichiers; 3. La valeur de retour nommée peut être modifiée; 4. Il sera exécuté même si la panique se produit, adaptée à la récupération; 5. éviter l'abus de report dans les boucles pour éviter la fuite des ressources; Une utilisation correcte peut améliorer la sécurité et la lisibilité du code.

La réponse claire à cette question est la recommandation d'implémenter le modèle d'observateur à l'aide d'une interface d'observateur personnalisée. 1. Bien que Java offre observable et observateur, le premier est une classe et a été obsolète et manque de flexibilité; 2. La pratique recommandée moderne consiste à définir une interface d'observateur fonctionnel, et le sujet maintient la liste des observateurs et informe tous les observateurs lorsque l'état change; 3. Il peut être utilisé en combinaison avec les expressions de lambda pour améliorer la simplicité et la maintenabilité du code; 4. Pour les scénarios GUI ou Javabean, PropertyChangeListener peut être utilisé. Par conséquent, les nouveaux projets devraient adopter un schéma d'interface d'observateur personnalisé, qui est sécurisé, facile à tester et se spécialise dans le Java moderne
