Firebase 函数在 xcode7 中冻结应用程序,但在 xcode6 中有效。4

Firebase function freezes app in xcode7, but works in xcode6.4

出于某种原因,此代码在 xcode6.4 中完美运行,但当切换到 xcode7 时,它会冻结应用程序。

我想做的是提取用户提要中的 post 信息并将其显示在表格视图中。我能够从 Firebase 中提取信息,但应用程序在显示在 tableview 上之前冻结了。

编辑:当我没有任何约束或自动布局时,tableview 可以工作。当我尝试动态单元格高度时,它似乎不起作用。

func getRadarData() {
    let url = "https://(insert appname).firebaseio.com/users/" + currentUser + "/postsReceived/"
    let targetRef = Firebase(url: url)

    targetRef.observeEventType(.ChildAdded, withBlock: {
        snapshot in
        print("child")

        if let found = self.posts.map({ [=12=].key }).indexOf(snapshot.key) {
            let obj = self.posts[found]
            print(obj)
            print(found)
            self.posts.removeAtIndex(found)
        }

        let postsUrl = "https://(insert appname).firebaseio.com/posts/" + snapshot.key
        let postsRef = Firebase(url: postsUrl)
        var updatedAt = snapshot.value["updatedAt"] as? NSTimeInterval
        var endAt = snapshot.value["endAt"] as? NSTimeInterval

        if updatedAt == nil {
            updatedAt = 0
        }

        if endAt == nil {
            endAt = 0
        }

        postsRef.observeSingleEventOfType(.Value, withBlock: { snapshot in
            if let key = snapshot.key
            {if let content = snapshot.value["content"] as? String {
                if let creator = snapshot.value["creator"] as? String {
                    if let createdAt = snapshot.value["createdAt"] as? NSTimeInterval {
                                let userurl = "https://(insert appname).firebaseio.com/users/" + (creator)
                                let userRef = Firebase(url: userurl)
                                userRef.observeSingleEventOfType(.Value, withBlock: { snapshot in
                                    if let username = snapshot.value["username"] as? String {
                                        let updatedDate = NSDate(timeIntervalSince1970: (updatedAt!/1000))
                                        let createdDate = NSDate(timeIntervalSince1970: (createdAt/1000))
                                        let endedDate = NSDate(timeIntervalSince1970: (endAt!))

                                        let post = Post(content: content, creator: creator, key: key, createdAt: updatedDate, name: username, joined: true, messageCount: 0, endAt: endedDate)

                                        self.posts.append(post)

                                        // Sort posts in descending order
                                        self.posts.sortInPlace({ [=12=].createdAt.compare(.createdAt) == .OrderedDescending })
                                        self.tableView.reloadData()

                                    }
                                })

                    }
                }
                }

            }
        })
    })
}

这是我的 tableview 代码,我在 textView 和 nameLabel 上使用了自动布局

    func tableView(tableView: UITableView, cellForRowAtIndexPath indexPath: NSIndexPath) -> UITableViewCell {

    let cell: RadarTableViewCell = tableView.dequeueReusableCellWithIdentifier("radarCell", forIndexPath: indexPath) as! RadarTableViewCell

    let creator: (String) = posts[indexPath.row].creator
    let key = posts[indexPath.row].key

    let radarContent: (AnyObject) = posts[indexPath.row].content
    cell.textView.selectable = false
    cell.textView.text = radarContent as? String
    cell.textView.userInteractionEnabled = false

    cell.textView.selectable = true

    let radarCreator: (AnyObject) = posts[indexPath.row].name

    cell.nameLabel.text = radarCreator as? String

    return cell

问题是我的 textView 中有初始文本。我在 Storyboard 上删除了它,我的应用程序现在可以运行了。

在此处找到解决方案: