如何暂停,而不是停止Swift中的应用程序/程序?

时间:2014-12-18 22:48:05

标签: core-data swift parse-platform

好的,这个问题甚至让我的计算机科学老师感到困惑,因为我们没有想到的任何工作。

以下是我的代码。因为我正在从Parse中检索数据,所以实际获取该数据会有一点延迟。并且计算机是计算机,即使没有检索到Parse数据,app也会继续执行代码。

我想做的就是告诉我的应用程序在继续之前停止执行代码,比如5秒,这样就可以检索解析数据并赶上程序。

我尝试过使用sleep (time)函数,但它只是停止整个程序的时间(因此Parse的数据检索也被置于保持状态)。另外,使用无用的for循环也可以完全相同。

我之所以这样问是因为我在打印test1时获得了零值。

此外,它看起来似乎正在打印“No Results”,这意味着我提取Core Data的东西出了问题....

import UIKit
import Darwin
import CoreData

class RegisterEmail: UIViewController {

var test1: Bool?
var userID: String!

override func viewDidLoad() {
    super.viewDidLoad()
}

override func didReceiveMemoryWarning() {
    super.didReceiveMemoryWarning()
    // Dispose of any resources that can be recreated.
}

override func shouldPerformSegueWithIdentifier(identifier: String!, sender: AnyObject!) -> Bool {
    if identifier == "passEmail" {


        var appDel:AppDelegate = (UIApplication.sharedApplication().delegate as AppDelegate)

        var context:NSManagedObjectContext = appDel.managedObjectContext!

        var request = NSFetchRequest(entityName: "Users")

        request.returnsObjectsAsFaults = false

        var results: NSArray = context.executeFetchRequest(request, error: nil)!

        if(results.count > 0)
        {
            var res = results [0] as NSManagedObject

            userID = res.valueForKey("userID") as String

        }

        var query = PFUser.query()
        query.getObjectInBackgroundWithId(userID) {
            (User: PFObject!, error: NSError!) -> Void in
            if error == nil {
                //NSLog("%@", User)


                var checkEmail = User["emailVerified"] as Bool

                println(checkEmail)

                var appDel:AppDelegate = (UIApplication.sharedApplication().delegate as AppDelegate)

                var context:NSManagedObjectContext = appDel.managedObjectContext!         

                var newEmail = NSEntityDescription.insertNewObjectForEntityForName("Email", inManagedObjectContext: context) as NSManagedObject

                newEmail.setValue(checkEmail, forKey: "emailStatus")

                context.save(nil)

            } else {
                NSLog("%@", error)
            }


        }


        var appDel1:AppDelegate = (UIApplication.sharedApplication().delegate as AppDelegate)

        var context1:NSManagedObjectContext = appDel1.managedObjectContext!

        var request1 = NSFetchRequest(entityName: "Email")

        request1.returnsObjectsAsFaults = false

        var results1: NSArray = context1.executeFetchRequest(request1, error: nil)!

        if(results1.count > 0)
        {
            var res1 = results1 [0] as NSManagedObject

            test1 = res1.valueForKey("emailVerified") as Bool
        }

        else
        {
            println("No results")
        }

        println (test1) //NIL VALUE


        if (test1 == false) {

            let alert = UIAlertView()
            alert.title = "Error"
            alert.message = "The email you have provided has not been verified."
            alert.addButtonWithTitle("Dismiss")
            alert.show()

            return false
        }

        else {

            return true
        }
    }

    // by default, transition
    return true
}
}

1 个答案:

答案 0 :(得分:0)

可以实现任意延迟时间
-(void)performSelector: withObject: afterDelay:   (NSObject)

但这并不是最有效的方式。因为获取数据可能只需要一次,几秒钟或从不在另一次。相反,您可以更好地查看完成块以推送数据进行打印。