如何比較字串建立的效能?

2019-10-16 22:31:22

在Java中,如何比較字串建立的效能?

以下範例比較了以兩種不同方式建立的兩個字串的效能。

package com.yiibai;

public class StringComparePerformance {
    public static void main(String[] args) {
        long startTime = System.currentTimeMillis();

        for (int i = 0; i < 50000; i++) {
            String s1 = "This is a String";
            String s2 = "This is a String";
        }
        long endTime = System.currentTimeMillis();
        System.out.println("Time taken for creation" + " of String literals : "
                + (endTime - startTime) + " milli seconds");
        long startTime1 = System.currentTimeMillis();

        for (int i = 0; i < 50000; i++) {
            String s3 = new String("This is a String");
            String s4 = new String("This is a String");
        }
        long endTime1 = System.currentTimeMillis();
        System.out.println("Time taken for creation" + " of String objects : "
                + (endTime1 - startTime1) + " milli seconds");
    }
}

執行上面範例程式碼,得到以下結果 -

Time taken for creation of String literals : 0 milli seconds
Time taken for creation of String objects : 16 milli seconds