Warning: file_get_contents(/data/phpspider/zhask/data//catemap/8/swift/19.json): failed to open stream: No such file or directory in /data/phpspider/zhask/libs/function.php on line 167

Warning: Invalid argument supplied for foreach() in /data/phpspider/zhask/libs/tag.function.php on line 1116

Notice: Undefined index: in /data/phpspider/zhask/libs/function.php on line 180

Warning: array_chunk() expects parameter 1 to be array, null given in /data/phpspider/zhask/libs/function.php on line 181
Ios 同步执行GET请求_Ios_Swift_Synchronous - Fatal编程技术网

Ios 同步执行GET请求

Ios 同步执行GET请求,ios,swift,synchronous,Ios,Swift,Synchronous,我有一个向API发送GET请求的函数,我需要等待响应,然后才能继续我的其余代码 我尝试过各种不同的线程,但都没有成功。我一直试图自己解决这个问题,但是我被线程和其他问题弄糊涂了 以下是我的职能: func checkDomains() { let endings = [".com"] for ending in endings { let domainName = names[randomNameIndx] + ending let urlStri

我有一个向API发送GET请求的函数,我需要等待响应,然后才能继续我的其余代码

我尝试过各种不同的线程,但都没有成功。我一直试图自己解决这个问题,但是我被线程和其他问题弄糊涂了

以下是我的职能:

func checkDomains() {
    let endings = [".com"]
    for ending in endings {
        let domainName = names[randomNameIndx] + ending
        let urlString = "https://domainr.p.mashape.com/v2/status?mashape-key={my-key}" + domainName

        let url = URL(string: urlString)
        var request = URLRequest(url: url!)

        request.setValue("{my-key}", forHTTPHeaderField: "X-Mashape-Key")
        request.setValue("application/json", forHTTPHeaderField: "Accept")
        request.httpMethod = "GET"
        var ourBool = false

        DispatchQueue.main.sync {
            let task = URLSession.shared.dataTask(with: request, completionHandler: { (data, response, er) in

                do {
                    print("hey")
                    if let json = try JSONSerialization.jsonObject(with: data!, options: .allowFragments) as? NSDictionary {
                        ourBool = String(describing: json).contains("inactive")

                        if ourBool {
                            self.domainStatuses.append("available")
                        } else {
                            self.domainStatuses.append("taken")
                        }
                    }
                } catch {

                }


            })
            task.resume()
        }
    }
}

@objc func btnTapped(sender: UIButton) {
        self.prepareForNewName()
        sender.shake(direction: "horizontal", swings: 1)
        self.checkDomains() // This needs to finish before calling the next functions
        self.setupForNewName()
        self.animateForNewName()
}

我的建议是在异步函数中添加回调参数。示例如下:

func checkDomains(_ onResult: @escaping (Error?) -> Void)
然后,您可以在服务器返回成功结果或错误的地方调用函数内部的onResult

func checkDomains(_ onResult: @escaping (Error?) -> Void) {
    ...
    let task = URLSession.shared.dataTask ... {
       do {
           //Parse response
           DispatchQueue.main.async { onResult(nil) }
       } catch {
           DispatchQueue.main.async { onResult(error) }
       }
       ...
    }
}
在调用
checkDomains
函数的地方,最后需要传递callback param

@objc func btnTapped(sender: UIButton) {
    self.prepareForNewName()
    sender.shake(direction: "horizontal", swings: 1)
    self.checkDomains { [unowned self] error in
        if let error = error {
            // handle error
            return
        }
        self.setupForNewName()
        self.animateForNewName()
    }
}

最近,异步进行网络调用是一种很好的做法。有一些技术可以简化代码,比如
TBC…

谢谢您的回答。我刚回到家,意识到有一种更简单的方法

let task = URLSession.shared.dataTask(with: request, completionHandler: { (data, response, error) in

    do {
            ...
            if response != nil {
                DispatchQueue.main.async {
                    self.setupForNewName()
                    self.animateForNewName()
                }
            }
        }
    } catch {
        print(error)
    }
})
task.resume()

当然,这取决于API的响应,但我有足够的信心API将始终响应

最近?异步进行网络调用一直是一种很好的做法。