获取类名:
1、在类的实例中可使用this.getClass().getName();但在static
method中不能使用该方法;
2、在static
method中使用方法:Thread.currentThread().getStackTrace()[1].getClassName();
获取方法名:Thread.currentThread().getStackTrace()[1].getMethodName();
获取代码行号:Thread.currentThread().getStackTrace()[1].getLineNumber();
Log 代码:
System.out.println("Class: "+this.getClass().getName()+" method: "+
Thread.currentThread().getStackTrace()[1].getMethodName() +" line:"+
Thread.currentThread().getStackTrace()[1].getLineNumber());
/s/blog_4a4f9fb50101eyfp.html
Description
Below I present you two different ways to get the current Class:
Using Thread
Using getClass()
The simplest way to get the name of the class where your code is being executed in is using thegetClass()method present in every java object. Like here:
Stringclazz=this.getClass().getName();
This works only if executed in an Object, namely an instanciated class. If you try to execute the code above in astaticmethod. It won't work. Even the keywordthisis
meaningless in a static method.
Also, the class returned by the above method may actually be a subclass of the class in which the method is defined. This is because subclasses inherit the methods of their parents; and getClass() returns the actual runtime type of the object. To get the actual
class in which a method is defined, use the method below also.
In astaticmethod you can instead use the following:
Stringclazz=Thread.currentThread().getStackTrace()[1].getClassName();
Which uses the static methodgetStackTrace()to get the whole stacktrace. This method returns an array, where the first element (index 0) is the getStackTrace() you called and the second element (index
1) is the method your code is in.
A similar trick can be used to find out the name of the method currently executed:
Stringmethod=Thread.currentThread().getStackTrace()[1].getMethodName();
It's exactly the same principle, just you dig out the name of the method instead of the class.
The code
packageorg.wikijava.reflection;
publicclassMethodName{publicstaticvoidmain(String[]args){
MethodName methodName=newMethodName();
Stringclazz=Thread.currentThread().getStackTrace()[1].getClassName();
Stringmethod=Thread.currentThread().getStackTrace()[1].getMethodName();
System.out.println("class name: "+clazz+" Method Name "+method);
methodName.anotherMethod();}
privatevoidanotherMethod(){
Stringclazz=this.getClass().getName();
Stringmethod=Thread.currentThread().getStackTrace()[1].getMethodName();
System.out.println("class name: "+clazz+" Method Name "+method);}}