java中String+String與StringBuilder的append()方法的效率問題
阿新 • • 發佈:2019-01-03
因為上一次的A題過程中,發現String的+總是超時,後來用到了append()方法,就過了。發現兩者的效率存在很大的區別,測試如下:
使用string的時間是:4471毫秒!public static void main(String[] args) { // TODO 自動生成的方法存根 String str = ""; StringBuffer sb = new StringBuffer(); long start = 0L; long end = 0L; start = System.currentTimeMillis(); for (int i = 0; i < 100000; i++) { str = str + "a"; } end = System.currentTimeMillis(); System.out.println("使用string的時間是:" + (end - start) + "毫秒!"); start = System.currentTimeMillis(); for (int i = 0; i < 100000; i++) { sb.append("a"); } end = System.currentTimeMillis(); System.out.println("使用StringBuffer的時間是:" + (end - start) + "毫秒!"); //System.out.println(getMax("aba")); }
使用StringBuffer的時間是:3毫秒!
這完全不是在一個層次上,希望各位謹記!大量字串連線一定要用append()方法,原因呢其實很簡單,字串連線每次都需要建立新的字串物件來儲存新串,這樣。。。。。。你懂得!