java 測試:iterator foreach for 三種迭代方式哪種更快?


代碼:

public class main {
    public static void main(String[] p_args){
        ArrayList<String> _l_string = new ArrayList<>();
        for (int o_a = 0; o_a < 100000; o_a++) {
            _l_string.add(String.valueOf(o_a));
        }
        c_public_countTime _countTime = new c_public_countTime();
        _countTime.f_begin();
        for (int i = 0; i < _l_string.size(); i++) {
            System.out.print(_l_string.get(i));
        }
        String _time_for = _countTime.f_done();
        _countTime.f_begin();
        for (String o_a :
                _l_string) {
            System.out.print(o_a);
        }
        String _time_foreach = _countTime.f_done();
        _countTime.f_begin();
        for (Iterator<String> o_iterator = _l_string.iterator(); o_iterator.hasNext();) {
            System.out.print(o_iterator.next());
        }
        String _time_iterator = _countTime.f_done();

        System.out.println("\niterator:" + _time_iterator + "\nfor:" + _time_for + "\nforeach:" + _time_foreach );
    }
}

結果:可能是由於 java 內部執行的原因,不同的順序造成的時長也各不相同,這里采集了一點數據樣本。

(速度、先后順序、時長)

#2 for:354 毫秒

#1 foreach:263 毫秒

#3 iterator:425 毫秒

小結:for 之后的 foreach 增加了速度。

=

#1 for:285 毫秒

#2 iterator:301 毫秒

#3 foreach:363 毫秒

小結:for 首次出場也獲得了最快速度。

===

#3 foreach:517 毫秒

#1 for:285 毫秒

#2 iterator:478 毫秒

小結:foreach 首次出場速度不佳,for 速度跟首次出場速度一致。

=

#3 foreach:416 毫秒

#1 iterator:317 毫秒

#2 for:321 毫秒

小結:即使在 iterator 獲得最快速度的時候,for 也有幾乎沒有差別的速度。 

===

#2 iterator:396 毫秒

#3 foreach:415 毫秒

#1 for:253 毫秒

小結:for 在最后出場的時候獲得了最快速度。

===

#3 iterator:417 毫秒
#1 for:332 毫秒
#2 foreach:334 毫秒

小結:for 獲得了最佳速度。

總結:iterator 和 foreach 並不會提高迭代的速度。所以應該通過必要的理由來使用它們,否則還是默認 for 比較快。

 


免責聲明!

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



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