Java for循環(huán)常見優(yōu)化方法案例詳解
更新時間:2021年08月31日 10:39:30 作者:Resourceful!
這篇文章主要介紹了Java for循環(huán)常見優(yōu)化方法案例詳解,本篇文章通過簡要的案例,講解了該項技術的了解與使用,以下就是詳細內(nèi)容,需要的朋友可以參考下
前言
我們都經(jīng)常使用一些循環(huán)耗時計算的操作,特別是for循環(huán),它是一種重復計算的操作,如果處理不好,耗時就比較大,如果處理書寫得當將大大提高效率,下面總結幾條for循環(huán)的常見優(yōu)化方式。
首先,我們初始化一個集合 list,如下:
List<String> list = new ArrayList<String>();
方法一:最常規(guī)的不加思考的寫法
for (int i = 0; i < list.size(); i++) { System.out.println(list.get(i)); }
- 優(yōu)點:較常見,易于理解
- 缺點:每次都要計算list.size()
方法二:數(shù)組長度提取出來
int m = list.size(); for (int i = 0; i < m; i++) { System.out.println(list.get(i)); }
- 優(yōu)點:不必每次都計算
- 缺點:
- 1.m的作用域不夠小,違反了最小作用域原則
2.不能在for循環(huán)中操作list的大小,比如除去或新加一個元素
方法三:數(shù)組長度提取出來
for (int i = 0, n = list.size(); i < n; i++) { System.out.println(list.get(i)); }
- 優(yōu)點:不必每次都計算 ,變量的作用域遵循最小范圍原則
- 缺點:
- 1.m的作用域不夠小,違反了最小作用域原則
2.不能在for循環(huán)中操作list的大小,比如除去或新加一個元素
方法四:采用倒序的寫法
for (int i = list.size() - 1; i >= 0; i--) { System.out.println(list.get(i)); }
- 優(yōu)點:不必每次都計算 ,變量的作用域遵循最小范圍原則
- 缺點:1、結果的順序會反 2、看起來不習慣,不易讀懂
- 適用場合:與顯示結果順序無關的地方:比如保存之前數(shù)據(jù)的校驗
方法五:Iterator 遍歷
for (Iterator<String> it = list.iterator(); it.hasNext();) { System.out.println(it.next()); }
- 優(yōu)點:簡潔
方法六:jdk1.5后的寫法
for (Object o : list) { System.out.println(o); }
- 優(yōu)點:簡潔結合泛型使用更簡潔
- 缺點:jdk1.4向下不兼容
方法七:循環(huán)嵌套外小內(nèi)大原則
for (int i = 0; i < 10; i++) { for (int j = 0; j < 10000; j++) { } }
原因
方法八:循環(huán)嵌套提取不需要循環(huán)的邏輯
//前: int a = 10, b = 11; for (int i = 0; i < 10; i++) { i = i * a * b; } //后: int c = a * b; for (int i = 0; i < 10; i++) { i = i * c; }
方法九:異常處理寫在循環(huán)外面
反例
for (int i = 0; i < 10; i++) { try { } catch (Exception e) { } }
正例
try { for (int i = 0; i < 10; i++) { } } catch (Exception e) { } catch (Exception e) { } }
正例
try { for (int i = 0; i < 10; i++) { } } catch (Exception e) { }
到此這篇關于Java for循環(huán)常見優(yōu)化方法案例詳解的文章就介紹到這了,更多相關Java for循環(huán)常見優(yōu)化方法內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關文章希望大家以后多多支持腳本之家!
相關文章
Java 根據(jù)某個 key 加鎖的實現(xiàn)方式
日常開發(fā)中,有時候需要根據(jù)某個 key 加鎖,確保多線程情況下,對該 key 的加鎖和解鎖之間的代碼串行執(zhí)行,這篇文章主要介紹了Java 根據(jù)某個 key 加鎖的實現(xiàn)方式,需要的朋友可以參考下2023-03-03