0

我的代码片段如下,我想在条件检查的 else 部分的列表中忽略/删除该值。offerRecords.remove(tariffOffer) 似乎不起作用

offerRecords.each { tariffOffer ->

    handsetData.each { hs ->
        if (tariffOffer.HANDSET_BAND.stringValue() == hs.HANDSET_BAND?.stringValue()) {
            //println 'condition is satisfied and set the handset id ****** '
            handset.add(hs.HANDSET_PKEY_ID?.stringValue())
        }

        if (handset.size() > 0) {
            // need to call a method
            recHandset = applyHandsetRulesCHL(tariffOffer, handset)
        }
        else {
            // ignore/remove the tariffOffer
            offerRecords.remove(tariffOffer) // i know it doesn't serve the purpose
        }
4

2 回答 2

1

只需在处理之前过滤您的列表:

def filteredList = handsetData.findAll{handset.size() > 0}

并处理过滤结果。顺便说一句,我不明白身体handset里有什么each{},但我想你明白了。

于 2013-05-24T08:39:28.870 回答
0

这是典型的java并发修改。

即在迭代列表时不能修改列表。

除了 Cat 先生早先提出的在迭代之前过滤数据的建议外,还有许多解决方案取决于您的用例的其他因素,请参阅This SO question

一个示例是保留无效条目的并行列表,然后在迭代完成后将它们从原始列表中删除:

def listToTest = ['a', 1, 'b', 'c']

def invalidItems = []
listToTest.each {
    if (it == 1)
        invalidItems << it
}

listToTest.removeAll invalidItems

assert ['a', 'b', 'c'] == listToTest
于 2013-05-24T14:39:32.683 回答