例:
public class Log4jTest {
class Innr{
}
private static Logger log = LogManager.getLogger(Log4jTest.class);
@Test
public void log4jTest(){
log.info("-----------内部类----------------");
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("-----------数组类----------------");
Class arrayClass = new Object[1].getClass();
log.info(arrayClass.getCanonicalName());
log.info(arrayClass.getName());
log.info(arrayClass.getSimpleName());
}
}
结果:
17:40:36.940 [main] INFO zengqiang.Log4jTest - -----------内部类----------------
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 - -----------数组类----------------
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[]
结论:
1、除了数组跟匿名类外,getCanonicalName()、getName()其它都相同,而getSimpleName()只是截取前面的包部分,只留下java代码中类名部分。
2、数组中getName()通过[L 表示数组,getCanonicalName()通过在定义的类型后面加上[]表示数组,而getSimpleName()只是去掉getCanonicalName()返回结果前面的包部分。getCanonicalName返回为null,getSimpleName就是空字符串。
3、匿名类中,因为匿名类在java语音规范中是不能呈现出类结构的,它的位置不能通过表名称表示出来,所以getCanonicalName()方法返回的是null,同理,getSimpleName()方法返回的是代码默认的空字符串,getName()返回通过$后面加上迭代数表示。
网友评论