在碼代碼的過程中,經常會遇到在循環中移除指定元素的需求。按照常規的思路,直接一個for循環,然后在循環里面來個if判斷,在判斷中刪除掉指定元素即可。但是實際情況往往不會像預想的那樣順利運行。
下面以一段Javascript代碼為例演示這一過程。
let arr = [1, 2, 3, 4, 5]; let len = arr.length; for(let i=0; i<len; i++) { if (arr[i]==2) { arr.splice(i, 1); } }
從最終的結果可以看到實際上只刪除掉了匹配的其中一個元素,而另外一個元素還存在。
從打印出的運行過程不難發現,原因為當刪除掉了一個元素后,數組的索引發生的變化,造成了程序的異常。
解決方法
方法一
let arr = [1, 2, 3, 4, 5]; let len = arr.length; for(let i=0; i<len; i++) { if (arr[i]==2) { arr.splice(i--, 1); } }
方法二
let arr = [1, 2, 3, 4, 5]; let len = arr.length; for(let i=len; i>=0; i--) { if (arr[i]==2) { arr.splice(i, 1); } }
從后往前遍歷可以有效解決問題
方法三
let arr = [1, 2, 3, 4, 5]; let i= arr.length; while(i--) { if (arr[i]==2) { arr.splice(i, 1); } }
使用while(i--) ,i為數組下標