Maison  >  Article  >  Java  >  Explication détaillée de l'exemple de code du mécanisme de réflexion Java

Explication détaillée de l'exemple de code du mécanisme de réflexion Java

黄舟
黄舟original
2017-03-27 10:53:351158parcourir

Cet article présente principalement l'explication détaillée et les exemples du mécanisme de réflexion Java. Les amis qui en ont besoin peuvent se référer à

Explication détaillée et exemples du mécanisme de réflexion Java

Réflexion, je les ai souvent entendus dire que j'avais lu certaines informations et que je les avais peut-être utilisées dans Design Pattern, mais j'avais l'impression de ne pas les comprendre en profondeur, je les ai réétudiées cette fois. et j'ai senti que tout allait bien.

Tout d'abord, jetons un coup d'œil au concept de réflexion :

Désigne principalement la capacité d'un programme à accéder, détecter et modifier son propre statut ou comportement. Et peut ajuster ou modifier l'état et la sémantique associée du comportement décrit par l'application en fonction de l'état et des résultats de son propre comportement.

Reflection est un outil puissant en Java qui nous permet de créer facilement du code flexible qui peut être assemblé au moment de l'exécution sans avoir besoin de relier le code source entre les composants. Mais une mauvaise utilisation de la réflexion peut coûter très cher !

Si le concept vous déroute, continuez à lire.

2. Le rôle du mécanisme de réflexion :

1. Décompiler : .class-->.Java

2. Accédez aux attributs, méthodes, méthode constructeur, etc. de l'objet java via le mécanisme de réflexion

Cela semble plus facile à comprendre. Voyons comment implémenter ces fonctions en détail.

Troisièmement, jetons un coup d'œil aux classes que le soleil nous offre dans le mécanisme de réflexion :

java.lang.Class;    
java.lang.reflect.Constructor; java.lang.reflect.Field;  
java.lang.reflect.Method;
java.lang.reflect.Modifier;
De nombreuses méthodes de réflexion, attributs, etc. opèrent sur nous Vous pouvez

interroger parmi ces quatre catégories. Ou devrions-nous apprendre à interroger constamment l'API, c'est notre meilleur professeur.

Quatrième implémentation de fonction spécifique :

1. Il existe trois façons d'obtenir la classe via le mécanisme de réflexion. Obtenons le type Employé

.

//第一种方式: 
Classc1 = Class.forName("Employee"); 
//第二种方式: 
//java中每个类型都有class 属性. 
Classc2 = Employee.class; 
 
//第三种方式: 
//java语言中任何一个java对象都有getClass 方法 
Employeee = new Employee(); 
Classc3 = e.getClass(); //c3是运行时类 (e的运行时类是Employee)
2.

Créer un objet : Après avoir obtenu la classe, nous créons son objet et utilisons newInstance :

Class c =Class.forName("Employee"); 
 
//创建此Class 对象所表示的类的一个新实例 
Objecto = c.newInstance(); //调用了Employee的无参数构造方法.
3. Obtenir les attributs : divisés en tous les attributs et spécifiés attributs :


a. Regardez d'abord comment obtenir tous les attributs :

//获取整个类 
   Class c = Class.forName("java.lang.Integer"); 
    //获取所有的属性? 
   Field[] fs = c.getDeclaredFields(); 
  
     //定义可变长的字符串,用来存储属性 
   StringBuffer sb = new StringBuffer(); 
   //通过追加的方法,将每个属性拼接到此字符串中 
   //最外边的public定义 
   sb.append(Modifier.toString(c.getModifiers()) + " class " + c.getSimpleName() +"{\n"); 
   //里边的每一个属性 
   for(Field field:fs){ 
    sb.append("\t");//空格 
    sb.append(Modifier.toString(field.getModifiers())+" ");//获得属性的修饰符,例如public,static等等 
    sb.append(field.getType().getSimpleName() + " ");//属性的类型的名字 
    sb.append(field.getName()+";\n");//属性的名字+回车 
   } 
  
   sb.append("}"); 
  
   System.out.println(sb);
b. Obtenez des attributs spécifiques et apprenez en les comparant avec les méthodes traditionnelles :

4. La méthode d'acquisition et la méthode de construction ne seront pas décrites en détail. Il suffit de regarder les mots-clés :
public static void main(String[] args) throws Exception{ 
    
<span style="white-space:pre"> </span>//以前的方式: 
 /* 
 User u = new User(); 
 u.age = 12; //set 
 System.out.println(u.age); //get 
 */ 
    
 //获取类 
 Class c = Class.forName("User"); 
 //获取id属性 
 Field idF = c.getDeclaredField("id"); 
 //实例化这个类赋给o 
 Object o = c.newInstance(); 
 //打破封装 
 idF.setAccessible(true); //使用反射机制可以打破封装性,导致了java对象的属性不安全。 
 //给o对象的id属性赋值"110" 
 idF.set(o, "110"); //set 
 //get 
 System.out.println(idF.get(o)); 
}


Méthode. mots-clés SignificationgetDeclaredMethods()Obtenir toutes les méthodes getReturnType()Obtenir le type de retour de la méthode getParameterTypes()Obtenir les types de paramètres entrants de la méthodegetDeclaredMethod ("Nom de la méthode", paramètre type.class,...) Obtenir une méthode spécifique Mot-clé constructeurSignificationgetDeclaredConstructors()Obtenir tous les constructeursgetDeclaredConstructor ( Paramètre type.class,...)Obtenir un constructeur spécifique Classe parent et interface parentSignificationgetSuperclass()Obtenir la classe parent d'une certaine classe getInterfaces ()Obtenir l'interface implémentée par un certain type

         这样我们就可以获得类的各种内容,进行了反编译。对于JAVA这种先编译再运行的语言来说,反射机制可以使代码更加灵活,更加容易实现面向对象。 

  五,反射加配置文件,使我们的程序更加灵活:

             在设计模式学习当中,学习抽象工厂的时候就用到了反射来更加方便的读取数据库链接字符串等,当时不是太理解,就照着抄了。看一下.NET中的反射+配置文件的使用:

             当时用的配置文件是app.config文件,内容是XML格式的,里边填写链接数据库的内容:

 <configuration> 
lt;appSettings> 
<add  key="" value=""/> 
lt;/appSettings> 
  </configuration>

 反射的写法:   

assembly.load("当前程序集的名称").CreateInstance("当前命名空间名称".要实例化的类名);

           这样的好处是很容易的方便我们变换数据库,例如我们将系统的数据库从SQL Server升级到Oracle,那么我们写两份D层,在配置文件的内容改一下,或者加条件选择一下即可,带来了很大的方便。            

         当然了,JAVA中其实也是一样,只不过这里的配置文件为.properties,称作属性文件。通过反射读取里边的内容。这样代码是固定的,但是配置文件的内容我们可以改,这样使我们的代码灵活了很多!

    综上为,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!

Déclaration:
Le contenu de cet article est volontairement contribué par les internautes et les droits d'auteur appartiennent à l'auteur original. Ce site n'assume aucune responsabilité légale correspondante. Si vous trouvez un contenu suspecté de plagiat ou de contrefaçon, veuillez contacter admin@php.cn