Maison  >  Article  >  Java  >  Comment obtenir le nom de classe actuel et l'instance de nom de méthode en Java

Comment obtenir le nom de classe actuel et l'instance de nom de méthode en Java

黄舟
黄舟original
2017-07-22 15:45:363014parcourir

Cet article présente principalement des informations pertinentes sur la méthode d'implémentation pour obtenir le nom de classe actuel et le nom de la méthode en Java. Il fournit non seulement la méthode d'implémentation et compare l'efficacité de plusieurs méthodes, les amis dans le besoin peuvent s'y référer

Méthode d'implémentation de Java pour obtenir le nom de classe et le nom de méthode actuels Voici quatre méthodes et comparaisons Vous pouvez vous y référer si vous en avez besoin. Testez chaque fonction. Si vous imprimez manuellement chaque nom de classe et chaque nom de fonction, tant de fonctions seront épuisantes. Java a déjà préparé un tas de fonctions qui s'enregistrent.

Obtenez le nom de la classe :


Exécutez 1 000 000 de fois,

public static void testGetClassName() { 
  // 方法1:通过SecurityManager的保护方法getClassContext() 
  String clazzName = new SecurityManager() { 
    public String getClassName() { 
      return getClassContext()[1].getName(); 
    } 
  }.getClassName(); 
  System.out.println(clazzName); 
  // 方法2:通过Throwable的方法getStackTrace() 
  String clazzName2 = new Throwable().getStackTrace()[1].getClassName(); 
  System.out.println(clazzName2); 
  // 方法3:通过分析匿名类名称() 
  String clazzName3 = new Object() { 
    public String getClassName() { 
      String clazzName = this.getClass().getName(); 
      return clazzName.substring(0, clazzName.lastIndexOf('$')); 
    } 
  }.getClassName(); 
  System.out.println(clazzName3); 
  //方法4:通过Thread的方法getStackTrace() 
  String clazzName4 = Thread.currentThread().getStackTrace()[2].getClassName(); 
  System.out.println(clazzName4); 
}
Première méthode : 1718 ms

Deuxième méthode : 4843 ms
Troisième méthode : 47 ms

Quatrième méthode : 6484 ms




Comparaison :

1) Existe-t-il des restrictions d'utilisation pour la méthode 1 ? 2) La méthode 2 obtient la pile d'appels via le mécanisme d'exception, qui a les pires performances, mais elle peut fournir des fonctions que les autres méthodes n'ont pas. Elle peut également obtenir des noms de méthodes, des numéros de ligne, etc. quelque peu non conventionnel de l'utiliser de cette façon ;
3) La méthode 3 analyse simplement le nom de la classe anonyme, ce qui est évidemment beaucoup plus simple, et a en fait les performances les plus élevées

4) La méthode 4 ressemble un peu à ; méthode 3, et est plus formelle que la méthode 3



Obtenir le nom de la fonction :


Exécuter 1 million de fois :

public static void testGetFunctionName() { 
    // 方法1:通过Throwable的方法getStackTrace() 
    String funcName2 = new Throwable().getStackTrace()[1].getMethodName(); 
    System.out.println(funcName2); 
    //方法2:通过Thread的方法getStackTrace() 
    String clazzName4 = Thread.currentThread().getStackTrace()[2].getMethodName(); 
    System.out.println(clazzName4);  
  }
Premier type : 4856 ms

Deuxième type : 6337 ms


Explication :

1. hérite de Throwable, donc certains endroits utilisent Exception pour appeler getStackTrace, en fait, il appelle Throwable
2. Différentes versions de jdk obtiennent des tableaux différents après avoir appelé getStackTrace. version jdk1.6

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