Math.random()和UUID.randomUUID().toString()性能對比
不言而喻,因為Math.random()不需要保證唯一性,所做的操作遠比UUID消耗更小的性能,
在部分要求不嚴格的場景,通過Math.random()和其它業務唯一碼仍能方便定位某條數據,此時就可以考慮使用Math.random().
壓測代碼如下:
package test; import java.util.UUID; public class Test { public static void main(String[] args) { mathRandom(); uuidRandom(); } public static void mathRandom() { long cost = 0; for (int i = 0; i < 100000; i++) { long start = System.currentTimeMillis(); double d = Math.random(); long end = System.currentTimeMillis(); cost += (end - start); } System.out.println("mathRandom:[" + cost + "]"); } public static void uuidRandom() { long cost = 0; for (int i = 0; i < 100000; i++) { long start = System.currentTimeMillis(); String uudi = UUID.randomUUID().toString(); long end = System.currentTimeMillis(); cost += (end - start); } System.out.println("uuidRandom:[" + cost + "]"); } }
10萬次循環,打印結果如下,相差近40倍:
mathRandom:[14]
uuidRandom:[428]