java反射 之 反射基础
一、反射
反射:JAVA反射机制是在运行状态中,对于任意一个类,都能够知道这个类的所有属性和方法;对于任意一个对象,都能够调用它的任意一个方法和属性;这种动态获取的信息以及动态调用对象的方法的功能称为java语言的反射机制。
要想解剖一个类,必须先要获取到该类的字节码文件对象。而解剖使用的就是Class类中的方法.所以先要获取到每一个字节码文件对应的Class类型的对象。对于反射的操作实际上就是通过Class对象获取:
*a、java.lang.reflect.Field:提供有关类或接口的单个字段的信息,以及对它的动态访问权限。反射的字段可能是一个类(静态)字段或实例字段。操作类的成员变量。
*b、java.lang.reflect.Constructor
*c、java.lang.reflect.Method:操作类的方法。
在学习反射基础前先创建一个Person对象作为实例
package com.jalja.org.base.relfect; public class Person { private String name; int age; public String address; public Person() { } private Person(String name) { this.name = name; } Person(String name, int age) { this.name = name; this.age = age; } public Person(String name, int age, String address) { this.name = name; this.age = age; this.address = address; } public void show() { System.out.println("show"); } public void method(String s) { System.out.println("method " + s); } public String getString(String s, int i) { return s + "---" + i; } private void function() { System.out.println("function"); } @Override public String toString() { return "Person [name=" + name + ", age=" + age + ", address=" + address + "]"; } }
二、获取类的Class对象
public static void getClassObject() throws ClassNotFoundException{ //方式一:Object的getClass()方法 Person person1=new Person(); Person person2=new Person(); Class c1=person1.getClass(); Class c2=person2.getClass(); System.out.println(person1==person2);//false System.out.println(c1==c2);//true 不管JVM内存中有多少个对象,对于字节码文件来说只有一份 //方式二:数据类型的静态class属性 Class c3=Person.class; System.out.println(c1==c3);//true //方式三:Class 类的静态方法 //public static Class<?> forName(String className)throws ClassNotFoundException Class c4=Class.forName("com.jalja.org.base.relfect.Person"); System.out.println(c1==c4);//true }
三、java.lang.reflect.Constructor
1、获取Constructor对象
//获取Class 对象所表示的类的构造方法 public static void getConstructorTest() throws Exception{ Class c4=Class.forName("com.jalja.org.base.relfect.Person"); //1、获取Class 对象所表示的类所有公共构造方法 //public Constructor<?>[] getConstructors() throws SecurityException Constructor [] cs=c4.getConstructors(); //2、获取Class 对象所表示的类所有构造方法 //public Constructor<?>[] getDeclaredConstructors() throws SecurityException Constructor[] cs2 =c4.getDeclaredConstructors(); //3、获取Class对象所表示类的指定指定公共构造方法, parameterTypes 参数是 Class 对象的一个数组 ,是指定数据类型的字节码 //public Constructor<T> getConstructor(Class<?>... parameterTypes); Constructor cs3=c4.getConstructor();//获取公共的无参构造方法的Constructor对象 //获取 该 构造函数 public Person(String name, int age, String address) Constructor cs4=c4.getConstructor(String.class,int.class,String.class); //4、获取Clss对象所表示类指定的构造范法官 parameterTypes 参数是 Class 对象的一个数组,它按声明顺序标识构造方法的形参类型的字节码。 //public Constructor<T> getDeclaredConstructor(Class<?>... parameterTypes); //获取该构造 函数 private Person(String name) 的Constructor对象 Constructor cs5=c4.getDeclaredConstructor(String.class); }
2、通过 Constructor 对象创建Class对象所表示类的实例
public static void createObject() throws Exception{ Class c4=Class.forName("com.jalja.org.base.relfect.Person"); //使用此 Constructor 对象表示的构造方法来创建该构造方法的声明类的新实例,并用指定的初始化参数初始化该实例 //public T newInstance(Object... initargs); // Person person=new Person() Constructor cs3=c4.getConstructor();//获取公共的无参构造方法的Constructor对象 Object obj=cs3.newInstance(); //Person person=new Person("jalja", 21, "北京"); Constructor cs4=c4.getConstructor(String.class,int.class,String.class); Object obj1=cs4.newInstance("jalja",21,"北京"); System.out.println(obj1);//Person [name=jalja, age=21, address=北京] //实例化一个私有的构造函数 private Person(String name) //控制java的访问检查 //public void setAccessible(boolean flag) //将此对象的 accessible 标志设置为指示的布尔值。值为 true 则指示反射的对象在使用时应该取消 Java 语言访问检查。 //值为 false 则指示反射的对象应该实施 Java 语言访问检查。 Constructor cs5=c4.getDeclaredConstructor(String.class); cs5.setAccessible(true); Object obj2=cs5.newInstance("张三丰"); System.out.println(obj2);//Person [name=张三丰, age=0, address=null] }
四、java.lang.reflect.Field
1、获取Field对象
//获取Class类的Field对象 public static void getFieldTest() throws Exception{ Class cs=Class.forName("com.jalja.org.base.relfect.Person"); //1、public Field[] getFields() throws SecurityException //获取Class 对象所表示的类或接口的所有可访问公共(public修饰的)字段 Field [] fs=cs.getFields(); //2、public Field[] getDeclaredFields() throws SecurityException // 获取Class 对象所表示的类或接口所声明的所有字段。包括公共、保护、默认(包)访问和私有字段,但不包括继承的字段 Field [] fs1=cs.getDeclaredFields(); //3、public Field getField(String name)throws NoSuchFieldException, SecurityException; //获取Class 对象所表示的类或接口的指定公共成员(public修饰)字段。name 参数是一个 String,用于指定所需字段的简称 Field fs2=cs.getField("address"); //public Field getDeclaredField(String name) throws NoSuchFieldException,SecurityException //获取 Class 对象所表示的类或接口的指定已声明字段。name 参数是一个 String,它指定所需字段的简称 Field fs3=cs.getDeclaredField("name"); System.out.println(fs3); }
2、通过Field对象对指定类属性赋值
//使用 Field对象 public static void createVarValue() throws Exception{ Class cs=Class.forName("com.jalja.org.base.relfect.Person"); Object obj=cs.getConstructor().newInstance(); Field addressField=cs.getField("address"); //public void set(Object obj, Object value); //将指定对象变量上此 Field 对象表示的字段设置为指定的新值。如果底层字段的类型为基本类型,则对新值进行自动解包 //obj - 应该修改其字段的对象 value - 正被修改的 obj 的字段的新值 addressField.set(obj, "北京"); System.out.println(obj); //Person [name=null, age=0, address=北京] //对非public修饰的变量操作 Field nameField=cs.getDeclaredField("name"); //控制java的访问检查 nameField.setAccessible(true); nameField.set(obj, "张三丰"); System.out.println(obj);//Person [name=张三丰, age=0, address=北京] }
五、java.lang.reflect.Method
1、获取Method对象
//获取Method对象 public static void getMethodTest() throws Exception{ Class cs=Class.forName("com.jalja.org.base.relfect.Person"); //1、public Method[] getMethods() throws SecurityException //获取Class 对象所表示的类或接口(包括那些由该类或接口声明的以及从超类和超接口继承的那些的类或接口)的公共 member 方法。 Method [] m1=cs.getMethods(); //2、public Method[] getDeclaredMethods() throws SecurityException //获取Class 对象表示的类或接口声明的所有方法,包括公共、保护、默认(包)访问和私有方法,但不包括继承的方法 Method [] m2=cs.getDeclaredMethods(); //3、public Method getMethod(String name, Class<?>... parameterTypes)throws NoSuchMethodException, SecurityException; // 获取Class 对象所表示的类或接口的指定公共成员方法。name 参数是一个 String,用于指定所需方法的简称。parameterTypes 参数是按声明顺序标识该方法形参类型的 Class 对象的一个数组 Method m3=cs.getMethod("show");//无参的方法 Method m4=cs.getMethod("method",String.class);//带参的方法 //public Method getDeclaredMethod(String name, Class<?>... parameterTypes)throws NoSuchMethodException,SecurityException // Class 对象所表示的类或接口的指定已声明方法。name 参数是一个 String,它指定所需方法的简称,parameterTypes 参数是 Class 对象的一个数组 Method m5=cs.getDeclaredMethod("function");//无参的方法 System.out.println(m5); }
2、通过Method对象调用指定类的方法
// Method对象的使用 public static void createMethod() throws Exception{ Class cs=Class.forName("com.jalja.org.base.relfect.Person"); Object obj=cs.getConstructor().newInstance(); Method m3=cs.getMethod("show");//无参的方法 //public Object invoke(Object obj,Object... args) //对带有指定参数的指定对象调用由此 Method 对象表示的底层方法 obj - 从中调用底层方法的对象 args - 用于方法调用的参数 m3.invoke(obj); //对带参方法的操作 Method m4=cs.getMethod("method",String.class);//带参的方法 m4.invoke(obj,"北京"); //对有返回值得方法操作 Method m6=cs.getMethod("getString",String.class,int.class);//带参的方法 Object str=m6.invoke(obj,"北京",200); System.out.println(str); //对私有无参方法的操作 Method m5=cs.getDeclaredMethod("function"); m5.setAccessible(true); m5.invoke(obj); }

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 grâce à 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.

Utilisez des classes dans le package Java.Time pour remplacer les anciennes classes de date et de calendrier; 2. Obtenez la date et l'heure actuelles via LocalDate, LocalDateTime et Localtime; 3. Créez une date et une heure spécifiques en utilisant la méthode OF (); 4. Utilisez la méthode plus / moins pour augmenter et diminuer le temps; 5. Utilisez ZonedDateTime et ZoneID pour traiter le fuseau horaire; 6. Format et chaînes de date d'analyse via DateTimeFormatter; 7. Utilisez instantanément pour être compatible avec les anciens types de dates si nécessaire; Le traitement des dattes dans le Java moderne devrait donner la priorité à l'utilisation de Java.timeapi, qui fournit clairement, immuable et linéaire

Setupamaven / gradleprojectwithjax-rsDependces likejersey; 2.CreateArestResourceUsingannotationsSuchas @ pathand @ get; 3.ConfigureTheApplicationViaApplicationsUbclassorweb.xml; 4.AddjacksonforjsonBindingByCludingJersey-Media-Json-Jackson; 5.DeploEp

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

DépendanceInjection (DI) IsadesignPatternwhereBjectSeveveveltency dexternal, promotionnloosecouplingAndreasiestingthroughroughConstructor, seter, orfieldInjection.2.springframeworkusesannotations like @ composant, @ service et @ autowiredwithjava-baskusecondotations like @ composant, @ service et @ autowiredwithjava-basesConfitations lik

Utilisez des outils d'analyse des performances pour localiser les goulots d'étranglement, utiliser VisualVM ou JProfiler dans la phase de développement et de test, et donner la priorité à l'async-profil dans l'environnement de production; 2. Réduire la création d'objets, réutiliser les objets, utiliser StringBuilder pour remplacer l'épissage de la chaîne et sélectionner les stratégies GC appropriées; 3. Optimiser l'utilisation de la collection, sélectionner et prérégler la capacité initiale selon la scène; 4. Optimiser la concurrence, utiliser des collections simultanées, réduire la granularité de verrouillage et régler raisonnablement le pool de threads; 5. Assurez les paramètres JVM, définissez la taille du tas raisonnable et le collecteur de déchets à faible latence et activez les journaux GC; 6. Évitez la réflexion au niveau du code, remplacez les classes de wrapper par des types de base, retardez l'initialisation et utilisez final et statique; 7. Test et surveillance des performances continues, combinées avec JMH

Maven est un outil standard pour la gestion et la construction de projet Java. La réponse réside dans le fait qu'il utilise pom.xml pour normaliser la structure du projet, la gestion des dépendances, l'automatisation du cycle de vie de la construction et les extensions de plug-in; 1. Utilisez pom.xml pour définir GroupID, Arfactive, version et dépendances; 2. Commandes Master Core telles que MvnClean, compiler, tester, package, installer et déploier; 3. Utiliser la fonction de dépendance et les exclusions pour gérer les versions et les conflits de dépendance; 4. Organisez de grandes applications via la structure du projet multi-modules et sont gérées uniformément par le POM parent; 5

Les capacités de «écriture, runany»
