91超碰碰碰碰久久久久久综合_超碰av人澡人澡人澡人澡人掠_国产黄大片在线观看画质优化_txt小说免费全本

溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務條款》

Stream性能測試實例分析

發布時間:2022-03-16 13:37:11 來源:億速云 閱讀:185 作者:iii 欄目:開發技術

本篇內容主要講解“Stream性能測試實例分析”,感興趣的朋友不妨來看看。本文介紹的方法操作簡單快捷,實用性強。下面就讓小編來帶大家學習“Stream性能測試實例分析”吧!

目錄

    一、反饋

    Stream性能測試實例分析

    問:stream比for循環慢5倍,用這個是為了啥? 答:互聯網是一個新聞泛濫的時代,三人成虎,以假亂真的事情時候發生。作為一個技術開發者,要自己去動手去做,不要人云亦云。

    的確,這位粉絲說的這篇文章我也看過,我就不貼地址了,也沒必要給他帶流量。怎么說呢?就是一個不懂得測試的、不入流開發工程師做的性能測試,給出了一個危言聳聽的結論。

    二、所有性能測試結論都是片面的

    性能測試是必要的,但針對性能測試的結果,永遠要持懷疑態度。為什么這么說?

    性能測試脫離業務場景就是片面的性能測試。你能覆蓋所有的業務場景么?性能測試脫離硬件環境就是片面的性能測試。你能覆蓋所有的硬件環境么?性能測試脫離開發人員的知識面就是片面的性能測試。你能覆蓋各種開發人員奇奇怪怪的代碼么?

    所以,我從來不相信網上的任何性能測試的文章。凡是我自己的從事的業務場景,我都要在接近生產環境的機器上自己測試一遍。 所有性能測試結論都是片面的,只有你生產環境下的運行結果才是真的。

    三、動手測試Stream的性能

    3.1.環境

    windows10 、16G內存、i7-7700HQ 2.8HZ 、64位操作系統、JDK 1.8.0_171

    3.2.測試用例與測試結論

    我們在上一節,已經講過:

    針對不同的數據結構,Stream流的執行效率是不一樣的針對不同的數據源,Stream流的執行效率也是不一樣的

    所以記住筆者的話:所有性能測試結論都是片面的,你要自己動手做,相信你自己的代碼和你的環境下的測試!我的測試結果僅僅代表我自己的測試用例和測試數據結構!

    3.2.1.測試用例一

    測試用例:5億個int隨機數,求最小值 測試結論(測試代碼見后文):

    使用普通for循環,執行效率是Stream串行流的2倍。也就是說普通for循環性能更好。Stream并行流計算是普通for循環執行效率的4-5倍。Stream并行流計算 > 普通for循環 > Stream串行流計算

    Stream性能測試實例分析

    3.2.測試用例二

    測試用例:長度為10的1000000隨機字符串,求最小值 測試結論(測試代碼見后文):

    普通for循環執行效率與Stream串行流不相上下Stream并行流的執行效率遠高于普通for循環Stream并行流計算 > 普通for循環 = Stream串行流計算

    Stream性能測試實例分析

    3.3.測試用例三

    測試用例:10個用戶,每人200個訂單。按用戶統計訂單的總價。 測試結論(測試代碼見后文):

    Stream并行流的執行效率遠高于普通for循環Stream串行流的執行效率大于等于普通for循環Stream并行流計算 > Stream串行流計算 >= 普通for循環 Stream性能測試實例分析

    四、最終測試結論 對于簡單的數字(list-Int)遍歷,普通for循環效率的確比Stream串行流執行效率高(1.5-2.5倍)。但是Stream流可以利用并行執行的方式發揮CPU的多核優勢,因此并行流計算執行效率高于for循環。對于list-Object類型的數據遍歷,普通for循環和Stream串行流比也沒有任何優勢可言,更不用提Stream并行流計算。

    雖然在不同的場景、不同的數據結構、不同的硬件環境下。Stream流與for循環性能測試結果差異較大,甚至發生逆轉。但是總體上而言:

    Stream并行流計算 >> 普通for循環 ~= Stream串行流計算 (之所以用兩個大于號,你細品)數據容量越大,Stream流的執行效率越高。Stream并行流計算通常能夠比較好的利用CPU的多核優勢。CPU核心越多,Stream并行流計算效率越高。

    stream比for循環慢5倍&#xff1f;也許吧&#xff0c;單核CPU、串行Stream的int類型數據遍歷&#xff1f;我沒試過這種場景&#xff0c;但是我知道這不是應用系統的核心場景。看了十幾篇測試博文&#xff0c;和我的測試結果。我的結論是&#xff1a; 在大多數的核心業務場景下及常用數據結構下&#xff0c;Stream的執行效率比for循環更高。 畢竟我們的業務中通常是實實在在的實體對象&#xff0c;沒事誰總對List<Int>類型進行遍歷&#xff1f;誰的生產服務器是單核&#xff1f;。

    五、測試代碼
    <dependency>    <groupId>com.github.houbb</groupId>    <artifactId>junitperf</artifactId>    <version>2.0.0</version></dependency>

    測試用例一&#xff1a;

    import com.github.houbb.junitperf.core.annotation.JunitPerfConfig;import com.github.houbb.junitperf.core.report.impl.HtmlReporter;import org.junit.jupiter.api.BeforeAll;import java.util.Arrays;import java.util.Random;public class StreamIntTest {    public static int[] arr;    @BeforeAll    public static void init() {        arr = new int[500000000];  //5億個隨機Int        randomInt(arr);    }    @JunitPerfConfig( warmUp = 1000, reporter = {HtmlReporter.class})    public void testIntFor() {        minIntFor(arr);    }    @JunitPerfConfig( warmUp = 1000, reporter = {HtmlReporter.class})    public void testIntParallelStream() {        minIntParallelStream(arr);    }    @JunitPerfConfig( warmUp = 1000, reporter = {HtmlReporter.class})    public void testIntStream() {        minIntStream(arr);    }    private int minIntStream(int[] arr) {        return Arrays.stream(arr).min().getAsInt();    }    private int minIntParallelStream(int[] arr) {        return Arrays.stream(arr).parallel().min().getAsInt();    }    private int minIntFor(int[] arr) {        int min = Integer.MAX_VALUE;        for (int anArr : arr) {            if (anArr < min) {                min = anArr;            }        }        return min;    }    private static void randomInt(int[] arr) {        Random r = new Random();        for (int i = 0; i < arr.length; i++) {            arr[i] = r.nextInt();        }    }}

    測試用例二&#xff1a;

    import com.github.houbb.junitperf.core.annotation.JunitPerfConfig;import com.github.houbb.junitperf.core.report.impl.HtmlReporter;import org.junit.jupiter.api.BeforeAll;import java.util.ArrayList;import java.util.Random;public class StreamStringTest {    public static ArrayList<String> list;    @BeforeAll    public static void init() {        list = randomStringList(1000000);    }    @JunitPerfConfig(duration = 10000, warmUp = 1000, reporter = {HtmlReporter.class})    public void testMinStringForLoop(){        String minStr = null;        boolean first = true;        for(String str : list){            if(first){                first = false;                minStr = str;            }            if(minStr.compareTo(str)>0){                minStr = str;            }        }    }    @JunitPerfConfig(duration = 10000, warmUp = 1000, reporter = {HtmlReporter.class})    public void textMinStringStream(){        list.stream().min(String::compareTo).get();    }    @JunitPerfConfig(duration = 10000, warmUp = 1000, reporter = {HtmlReporter.class})    public void testMinStringParallelStream(){        list.stream().parallel().min(String::compareTo).get();    }    private static ArrayList<String> randomStringList(int listLength){        ArrayList<String> list = new ArrayList<>(listLength);        Random rand = new Random();        int strLength = 10;        StringBuilder buf = new StringBuilder(strLength);        for(int i=0; i<listLength; i++){            buf.delete(0, buf.length());            for(int j=0; j<strLength; j++){                buf.append((char)('a'+ rand.nextInt(26)));            }            list.add(buf.toString());        }        return list;    }}

    測試用例三&#xff1a;

    import com.github.houbb.junitperf.core.annotation.JunitPerfConfig;import com.github.houbb.junitperf.core.report.impl.HtmlReporter;import org.junit.jupiter.api.BeforeAll;import java.util.*;import java.util.stream.Collectors;public class StreamObjectTest {    public static List<Order> orders;    @BeforeAll    public static void init() {        orders = Order.genOrders(10);    }    @JunitPerfConfig(duration = 10000, warmUp = 1000, reporter = {HtmlReporter.class})    public void testSumOrderForLoop(){        Map<String, Double> map = new HashMap<>();        for(Order od : orders){            String userName = od.getUserName();            Double v;             if((v=map.get(userName)) != null){                map.put(userName, v+od.getPrice());            }else{                map.put(userName, od.getPrice());            }        }    }    @JunitPerfConfig(duration = 10000, warmUp = 1000, reporter = {HtmlReporter.class})    public void testSumOrderStream(){        orders.stream().collect(                Collectors.groupingBy(Order::getUserName,                         Collectors.summingDouble(Order::getPrice)));    }    @JunitPerfConfig(duration = 10000, warmUp = 1000, reporter = {HtmlReporter.class})    public void testSumOrderParallelStream(){        orders.parallelStream().collect(                Collectors.groupingBy(Order::getUserName,                         Collectors.summingDouble(Order::getPrice)));    }}class Order{    private String userName;    private double price;    private long timestamp;    public Order(String userName, double price, long timestamp) {        this.userName = userName;        this.price = price;        this.timestamp = timestamp;    }    public String getUserName() {        return userName;    }    public double getPrice() {        return price;    }    public long getTimestamp() {        return timestamp;    }    public static List<Order> genOrders(int listLength){        ArrayList<Order> list = new ArrayList<>(listLength);        Random rand = new Random();        int users = listLength/200;// 200 orders per user        users = users==0 ? listLength : users;        ArrayList<String> userNames = new ArrayList<>(users);        for(int i=0; i<users; i++){            userNames.add(UUID.randomUUID().toString());        }        for(int i=0; i<listLength; i++){            double price = rand.nextInt(1000);            String userName = userNames.get(rand.nextInt(users));            list.add(new Order(userName, price, System.nanoTime()));        }        return list;    }    @Override    public String toString(){        return userName + "::" + price;    }}

    到此,相信大家對“Stream性能測試實例分析”有了更深的了解,不妨來實際操作一番吧!這里是億速云網站,更多相關內容可以進入相關頻道進行查詢,關注我們,繼續學習!

    向AI問一下細節

    免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。

    AI

    织金县| 高密市| 盖州市| 陇川县| 淮阳县| 平遥县| 武冈市| 花莲市| 双桥区| 凉城县| 东兴市| 尼玛县| 彰化市| 宁蒗| 攀枝花市| 财经| 黄山市| 尉氏县| 广州市| 东安县| 舞钢市| 五大连池市| 潮州市| 河北区| 浦县| 广东省| 巴彦淖尔市| 龙川县| 东明县| 顺平县| 茂名市| 灌南县| 邢台县| 高唐县| 聂拉木县| 鄂州市| 米林县| 安吉县| 重庆市| 延庆县| 昔阳县|