Math.random()和UUID.randomUUID().toString()性能對比【純原】


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]

 


免責聲明!

本站轉載的文章為個人學習借鑒使用,本站對版權不負任何法律責任。如果侵犯了您的隱私權益,請聯系本站郵箱yoyou2525@163.com刪除。



 
粵ICP備18138465號   © 2018-2025 CODEPRJ.COM