List<String> list = new ArrayList<>(); for (int i = 0; i < 10000000; i++) { list.add("value-" + i); } Long startTime = System.currentTimeMillis(); for (String value : list) { if ("222".equals("222")) { if ("222".equals("222")) { if ("555".equals("555")) { if ("222".equals("222")) { value.concat("value"); } } } } } Long endTime = System.currentTimeMillis(); System.out.println(endTime - startTime); Long startTime2 = System.currentTimeMillis(); for (int i = 0; i < list.size(); i++) { if ("222".equals("222")) { if ("222".equals("222")) { if ("222".equals("222")) { if ("222".equals("222")) { if ("222".equals("222")) { if ("222".equals("222")) { String value = list.get(i); value.concat("value" + i); } } } } } } } Long endTime2 = System.currentTimeMillis(); System.out.println(endTime2 - startTime2); Long startTime3 = System.currentTimeMillis(); for (int i = 0, length = list.size(); i < length; i++) { if ("888".equals("888")) { if ("888".equals("888")) { if ("888".equals("888")) { if ("888".equals("888")) { if ("888".equals("888")) { if ("888".equals("888")) { String value = list.get(i); value.concat("value" + i); } } } } } } } Long endTime3 = System.currentTimeMillis(); System.out.println(endTime3 - startTime3);
2455 516 533 Process finished with exit code 0
明確一個概念,對方法的調用,即便方法中只有一句語句,也是有消耗的,包括建立棧幀、調用方法時保護現場、調用方法完畢時恢復現場等。性能
謝謝各位看官評論。測試