【问题标题】:Iterating along a Dictionary in Swift 3在 Swift 3 中沿字典进行迭代
【发布时间】:2016-11-17 18:44:33
【问题描述】:

我正在尝试沿字典进行迭代以修剪未确认的条目。以下 Objective-C 代码的 Swift 3 翻译不起作用:

[[self sharingDictionary] enumerateKeysAndObjectsUsingBlock: ^(id key, id obj, BOOL *stop) {
                    SharingElement* element=[[self sharingDictionary] objectForKey:key];
                    if (!element.confirmed){
                        dispatch_async(dispatch_get_main_queue(), ^{
                            [element deleteMe];
                        });
                        [[self sharingDictionary] performSelector:@selector(removeObjectForKey:) withObject:key
                                                       afterDelay:.2];
                    } else{
                        element.confirmed=NO;
                }];

所以我尝试以这种方式使用以下紧凑的 enumerated() 方法:

for (key, element) in self.sharingDictionary.enumerated(){
            if (!element.confirmed){
                    element.deleteMe()
                self.perform(#selector(self.removeSharingInArray(key:)), with:key, afterDelay:0.2);
            } else{
                element.confirmed=false
            }
        }

但编译器在处理变量'element'的使用时报告以下错误:

元组类型 '(key: Int, value: SharingElement)' 的值没有成员 '确认'

like 'element' 取了full tuple 的父亲部分而不是它的权限。 是 enumerated() 的使用问题还是字典的处理问题,我该如何解决?

【问题讨论】:

    标签: dictionary enumerate swift3


    【解决方案1】:

    使用element.value.confirmedelement 是一个包含 keyvalue 的元组。

    但您可能只想删除enumerated()

    for (key, element) in self.sharingDictionary {
        ...
    }
    

    enumerated() 进行迭代并添加从零开始的索引。这在字典中使用并不常见。

    【讨论】:

      【解决方案2】:

      这应该可以解决问题,

              localDictionary.enumerateKeysAndObjects ({ (key, value, stop) -> Void in
      
          })
      

      【讨论】:

        【解决方案3】:

        我最终将事情实现为:

        DispatchQueue.global(attributes: .qosBackground).async{
                    for (key, element) in self.sharingDictionary{
                        if !element.confirmed{
                            DispatchQueue.main.async({
                                element.deleteMe()
                                self.removeSharingInArray(key:key)
                            })
                        } else{
                            element.confirmed=false
                        }
                    }
                }
        

        因此,希望在不更改字典的情况下在浏览对象的情况下删除对象,是什么导致应用程序崩溃,即使我不知道它是否仍然如此。

        【讨论】:

          猜你喜欢
          • 2017-10-29
          • 1970-01-01
          • 1970-01-01
          • 2014-09-12
          • 2011-04-06
          • 2017-01-22
          • 2015-02-28
          • 1970-01-01
          • 2016-01-04
          相关资源
          最近更新 更多