复制代码
public static void main(String[] args) {
ReceiveProcess receiveProcess;
ApplicationContext appCt = new ClassPathXmlApplicationContext("classpath:applicationContext.xml");
long begin = System.currentTimeMillis();
int num = 10000000;
for (int i = 0; i < num; i++) {
receiveProcess = (ReceiveProcess) appCt.getBean("textReceive");
}
System.out.println("spring得到实例总时间:" + (System.currentTimeMillis() - begin));
long begin2 = System.currentTimeMillis();
ReceiveProcess re = null;
for (int j = 0; j < num; j++) {
re = new TextReceiveProcess();
}
System.out.println("创建实例得到的总时间:"+ (System.currentTimeMillis() - begin2));
ReceiveProcess reInstance = null;;
long begin3 = System.currentTimeMillis();
for (int d = 0; d < num; d++) {
reInstance = TextReceiveProcess.getInstance();
}
System.out.println("单例情况下得到总时间:"+(System.currentTimeMillis() - begin3));
}
复制代码
得到的结果:
spring得到实例总时间:5257
创建实例得到的总时间:48
单例情况下得到总时间:16
偶尔会出现这种结果,这个结果我就有点不是很理解了,有时候创建的对象和单例得到的实例时间差不多,这是为什么了?
spring得到实例总时间:5258
创建实例得到的总时间:32
单例情况下得到总时间:31