例:
public class Log4jTest {
class Innr{
}
private static Logger log = LogManager.getLogger(Log4jTest.class);
@Test
public void log4jTest(){
log.info("-----------內(nèi)部類----------------");
Class innr = Innr.class;
log.info(innr.getCanonicalName());
log.info(innr.getName());
log.info(innr.getSimpleName());
log.info("-----------匿名類----------------");
Class anonymousClass = new Object(){}.getClass();
log.info(anonymousClass.getCanonicalName());
log.info(anonymousClass.getName());
log.info(anonymousClass.getSimpleName());
log.info("-----------數(shù)組類----------------");
Class arrayClass = new Object[1].getClass();
log.info(arrayClass.getCanonicalName());
log.info(arrayClass.getName());
log.info(arrayClass.getSimpleName());
}
}
結(jié)果:
17:40:36.940 [main] INFO zengqiang.Log4jTest - -----------內(nèi)部類----------------
17:40:36.944 [main] INFO zengqiang.Log4jTest - zengqiang.Log4jTest.Innr
17:40:36.944 [main] INFO zengqiang.Log4jTest - zengqiang.Log4jTest$Innr
17:40:36.944 [main] INFO zengqiang.Log4jTest - Innr
17:40:36.944 [main] INFO zengqiang.Log4jTest - -----------匿名類----------------
17:40:36.945 [main] INFO zengqiang.Log4jTest - null
17:40:36.945 [main] INFO zengqiang.Log4jTest - zengqiang.Log4jTest$1
17:40:36.946 [main] INFO zengqiang.Log4jTest -
17:40:36.946 [main] INFO zengqiang.Log4jTest - -----------數(shù)組類----------------
17:40:36.946 [main] INFO zengqiang.Log4jTest - java.lang.Object[]
17:40:36.946 [main] INFO zengqiang.Log4jTest - [Ljava.lang.Object;
17:40:36.946 [main] INFO zengqiang.Log4jTest - Object[]
結(jié)論:
1趴拧、除了數(shù)組跟匿名類外溅漾,getCanonicalName()、getName()其它都相同著榴,而getSimpleName()只是截取前面的包部分添履,只留下java代碼中類名部分。
2脑又、數(shù)組中getName()通過[L 表示數(shù)組暮胧,getCanonicalName()通過在定義的類型后面加上[]表示數(shù)組,而getSimpleName()只是去掉getCanonicalName()返回結(jié)果前面的包部分问麸。getCanonicalName返回為null往衷,getSimpleName就是空字符串。
3严卖、匿名類中席舍,因為匿名類在java語音規(guī)范中是不能呈現(xiàn)出類結(jié)構的,它的位置不能通過表名稱表示出來哮笆,所以getCanonicalName()方法返回的是null,同理来颤,getSimpleName()方法返回的是代碼默認的空字符串,getName()返回通過$后面加上迭代數(shù)表示稠肘。