我知道已經有人問過類似的問題,但每次答案都圍繞“使用地圖代替”。就我而言,我必須使用列表。更準確地說,我可以使用其他數據結構來處理,但信息最終會以List的形式存儲。情況如下:我有一個我將調用的對象Sequence,其中包含List我將調用的對象Phase。除其他屬性外,該Phase對象還通過以下方式獲得 UUID:ObjectId在給定的處理過程中,我必須用另一個替換包含Phase 在List<Phase>其中的現有內容。其輸入是替換對象和要替換的值SequencePhasePhaseStringObjectIdPhase我希望能夠使用 Java8 做這樣的事情:public void replacePhase(Sequence sequence, Phase replacementPhase, String idPhaseToBeReplaced) { List<Phase> phaseList = sequence.getPhaseslist(); Phase phaseToBeReplaced = phaseList.stream().filter(p -> p.getId().toString().equalsIgnoreCase(idPhaseToBeReplaced)).findFirst().orElse(null); if (phaseToBeReplaced != null) { phaseToBeReplaced = replacementPhase; }瞧,List<Phase>將會更新。我知道這樣的事情會起作用: public void replacePhase(Sequence sequence, Phase replacementPhase, String idPhaseToBeReplaced) { List<Phase> phaseList = sequence.getPhaseslist(); Phase phaseToBeReplaced = phaseList.stream().filter(p -> p.getId().toString().equalsIgnoreCase(idPhaseToBeReplaced)).findFirst().orElse(null); if (phaseToBeReplaced != null) { int i = phaseList.indexOf(phaseToBeReplaced ); phaseList.set(i, replacementPhase); phaseToBeReplaced = replacementPhase; }但是,當找到具有所需 UUID 的a時,使用 afor循環似乎并不更有效。phaseListbreakPhase所以我的問題是:有沒有一種方法,使用 List 數據結構,找到基于(在本例中是唯一的)屬性的對象,然后用另一個(相同類型的)替換 List 中的所述對象,同時保留順序?最好不要迭代整個列表并使用 Java8 功能?
3 回答

白衣染霜花
TA貢獻1796條經驗 獲得超10個贊
為了使您的替換功能以短路方式工作,請使用ListIterator:
ListIterator<Phase> iterator = phaseList.listIterator();
while(iterator.hasNext()){
Phase phase = iterator.next();
if(phase.getId().toString().equalsIgnoreCase(idPhaseToBeReplaced)){
iterator.set(replacementPhase);
break;
}
}
如果 id 不唯一,只需刪除break. 或者使用List::replaceAll.

喵喔喔
TA貢獻1735條經驗 獲得超5個贊
您似乎正在尋找List#replaceAll
諸如:
sequence.getPhasesList() ????????.replaceAll(phase?->?phase.getId().toString() ????????????????.equalsIgnoreCase(idPhaseToBeReplaced)???replacementPhase?:?phase);

largeQ
TA貢獻2039條經驗 獲得超8個贊
如果保持列表排序,則可以使用二分搜索找到該項目,這比迭代列表更快。
Collections.binarySearch
如果您需要按插入順序對其進行排序,請使用LinkedHashMap
添加回答
舉報
0/150
提交
取消