Swift:无法分配类型' AnyObject的不可变表达式?!'

时间:2015-08-19 11:03:34

标签: ios xcode swift parse-platform

我搜索过,但我没有找到熟悉的答案,所以......

我即将编写一个类来处理更新,添加,提取和删除等解析方法。

func updateParse(className:String, whereKey:String, equalTo:String, updateData:Dictionary<String, String>) {

    let query = PFQuery(className: className)

    query.whereKey(whereKey, equalTo: equalTo)
    query.findObjectsInBackgroundWithBlock {(objects, error) -> Void in
        if error == nil {
            //this will always have one single object
            for user in objects! {
                //user.count would be always 1
                for (key, value) in updateData {

                    user[key] = value //Cannot assign to immutable expression of type 'AnyObject?!'

                }

                user.saveInBackground()
            } 

        } else {
            print("Fehler beim Update der Klasse \(className) where \(whereKey) = \(equalTo)")
        }
    }

}

由于我现在即将学习迅速,我很乐意通过一个小小的宣言得到答案,以便我能多学习一点。

btw:我后来这样称呼这个方法:

parseAdd.updateParse("UserProfile", whereKey: "username", equalTo: "Phil", updateData: ["vorname":self.vornameTextField!.text!,"nachname":self.nachnameTextField!.text!,"telefonnummer":self.telefonnummerTextField!.text!])

2 个答案:

答案 0 :(得分:30)

在swift中,很多类型被定义为struct s,默认情况下它们是不可变的。

我这样做有同样的错误:

protocol MyProtocol {
    var anInt: Int {get set}
}

class A {

}

class B: A, MyProtocol {
    var anInt: Int = 0
}

在另一个班级:

class X {

   var myA: A

   ... 
   (self.myA as! MyProtocol).anInt = 1  //compile error here
   //because MyProtocol can be a struct
   //so it is inferred immutable
   //since the protocol declaration is 
   protocol MyProtocol {...
   //and not 
   protocol MyProtocol: class {...
   ...
}

所以一定要

protocol MyProtocol: class {

进行此类投射时

答案 1 :(得分:9)

错误消息显示,您正在尝试更改不可变对象,这是不可能的。

默认情况下,声明为方法参数或闭包中返回值的对象是不可变的。

要使对象可变,要么在方法声明中添加关键字var,要么添加一行来创建可变对象。

默认情况下,重复循环中的索引变量也是不可变的。

在这种情况下,插入一行以创建可变副本,并将索引变量声明为可变。

在枚举时小心更改对象,这可能会导致意外行为

...
query.findObjectsInBackgroundWithBlock {(objects, error) -> Void in
    if error == nil {
        //this will always have one single object
        var mutableObjects = objects
        for var user in mutableObjects! {
            //user.count would be always 1
            for (key, value) in updateData {

                user[key] = value
...