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); }
Deuxième méthode : 4843 ms
Troisième méthode : 47 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
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); }
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!