我正在尝试使用信号量让代码等待Firebase查询结果。
代码如下:
var valor: Decimal = 0
let dateFormatter = DateFormatter()
let semaphore = DispatchSemaphore(value: 0)
dateFormatter.dateFormat = "mm/dd/yyyy"
//procedimenton para leitura dos dados no Firebase e jogar no array
Constants.refs.databaseRoot.child("Lancamentos").queryOrdered(byChild: "ContaDebito").queryEqual(toValue: "1.1.6").observe(.value, with: { snapshot in
if let snapshots = snapshot.children.allObjects as? [DataSnapshot] {
for snap in snapshots {
if let postDict = snap.value as? Dictionary<String, AnyObject> {
let post = FIRLancamento()
post.setValuesForKeys(postDict)
let credito = post.Valor
valor += Decimal(string: credito)!
print (credito + " " + String(describing: valor))
}
}
semaphore.signal()
}
})
semaphore.wait()
print(valor)
当我运行此代码时,信号灯信号永远不会被触发,程序保持冻结状态,我在控制台中看到以下错误:
2017-10-26 16:55:23.830048-0400 BVI_Swift[10830:1929792] TIC TCP 连接失败 [1:0x604000169a80]: 3:-9802 错误(-9802)2017-10-26 16:55:23.831266-0400 BVI_Swift[10830:1929792] NSURLSession/NSURLConnection HTTP load 失败 (kCFStreamErrorDomainSSL, -9802)2017-10-26 16:55:23.831597-0400 BVI_Swift[10830:1929792] 任务 .HTTP 加载失败(错误代码:-1200 [3:-9802])2017-10-26 16:55:23.832476-0400 BVI_Swift[10830:1929780] 任务 .已完成但出现错误 - 代码:-1200
如果我注释semaphore.wait()
行,查询将正常工作,但print(valor)
行在具有任何值之前执行。
执行此操作
时会阻塞主线程吗?举个例子;如果在按钮选择器函数中运行此块并且不返回;所有应用程序都将冻结,因此semaphore.signal()
永远不会执行。
尝试像这样运行该块:
func buttonClick() {
DispatchQueue.global(qos: .background).async {
// your sync firebase operation
// ...
}
}