代碼中大量的套娃式for循環(huán),你有哪幾種方案可以?xún)?yōu)化?
閱讀本文大概需要 2.8 分鐘。
前言
List<String> list = new ArrayList<String>();
方法一:最常規(guī)的不加思考的寫(xiě)法
for (int i = 0; i < list.size(); i++) {
System.out.println(list.get(i));
}
優(yōu)點(diǎn):較常見(jiàn),易于理解
缺點(diǎn):每次都要計(jì)算
list.size()
方法二:數(shù)組長(zhǎng)度提取出來(lái)
int m = list.size();
for (int i = 0; i < m; i++) {
System.out.println(list.get(i));
}
優(yōu)點(diǎn):不必每次都計(jì)算
缺點(diǎn):
m的作用域不夠小,違反了最小作用域原則 不能在for循環(huán)中操作list的大小,比如除去或新加一個(gè)元素
方法三:數(shù)組長(zhǎng)度提取出來(lái)
for (int i = 0, n = list.size(); i < n; i++) {
System.out.println(list.get(i));
}
優(yōu)點(diǎn):不必每次都計(jì)算 ,變量的作用域遵循最小范圍原則
缺點(diǎn):
m的作用域不夠小,違反了最小作用域原則 不能在for循環(huán)中操作list的大小,比如除去或新加一個(gè)元素
方法四:采用倒序的寫(xiě)法
for (int i = list.size() - 1; i >= 0; i--) {
System.out.println(list.get(i));
}
優(yōu)點(diǎn):不必每次都計(jì)算 ,變量的作用域遵循最小范圍原則
缺點(diǎn):1、結(jié)果的順序會(huì)反 2、看起來(lái)不習(xí)慣,不易讀懂
適用場(chǎng)合:與顯示結(jié)果順序無(wú)關(guān)的地方:比如保存之前數(shù)據(jù)的校驗(yàn)
方法五:Iterator 遍歷
for (Iterator<String> it = list.iterator(); it.hasNext();) {
System.out.println(it.next());
}
優(yōu)點(diǎn):簡(jiǎn)潔
方法六:jdk1.5后的寫(xiě)法
for (Object o : list) {
System.out.println(o);
}
優(yōu)點(diǎn):簡(jiǎn)潔結(jié)合泛型使用更簡(jiǎn)潔
缺點(diǎn):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;
}
方法九:異常處理寫(xiě)在循環(huán)外面
for (int i = 0; i < 10; i++) {
try {
} catch (Exception e) {
}
}
try {
for (int i = 0; i < 10; i++) {
}
} catch (Exception e) {
}
推薦閱讀:
為什么代碼規(guī)范要求SQL語(yǔ)句不要過(guò)多的join?
內(nèi)容包含Java基礎(chǔ)、JavaWeb、MySQL性能優(yōu)化、JVM、鎖、百萬(wàn)并發(fā)、消息隊(duì)列、高性能緩存、反射、Spring全家桶原理、微服務(wù)、Zookeeper、數(shù)據(jù)結(jié)構(gòu)、限流熔斷降級(jí)......等技術(shù)棧!
?戳閱讀原文領(lǐng)?。?/span> 朕已閱 
評(píng)論
圖片
表情

