#swift
#быстрый
Вопрос:
Это заставляет меня задуматься. Я пытаюсь показать счетчик, а затем удалить его после выполнения задачи.
К сожалению, код удаления счетчика выполняется до завершения задачи. Любая помощь будет оценена.
DispatchQueue.global(qos: .utility).async { [weak self] in // Create a new queue for our networking activity
guard let self = self else {
return
}
switch airframe{
case .A_10:
dcsBIOSConn.configureHawgWaypoint(name: name, lat: latitude!, long: longitude!, elev: elev, tot: timeOnTarget)
case .F_16:
dcsBIOSConn.configureWaypoint(lat: latitude!, long: longitude!, elev: elev, aircraft: airframe!)
case .F_18:
dcsBIOSConn.configureWaypoint(lat: latitude!, long: longitude!, elev: elev, aircraft: airframe!)
case .AV_8B:
dcsBIOSConn.configureWaypoint(lat: latitude!, long: longitude!, elev: elev, aircraft: airframe!)
default:
break
}
dcsBIOSConn.printMessageQueue()
print("1. Entering Queue")
let biosQueue = DispatchQueue(label: "dcs_bios")
biosQueue.async {
dcsBIOSConn.sendMessageQueueToDCSBIOS()
}
print("2. Finishing Out of Loop")
// Send the designated coord to the CDU radio.
DispatchQueue.main.async { [weak self] in // Update the spinner on the main thread.
self?.removeSpinner()
//ERProgressHud.sharedInstance.hide()
print("3. Remove Spinner")
}
}
Дает этот результат
AAP_PAGE
CDU_CLR
CDU_LSK_7R
CDU_Q
CDU_E
CDU_S
CDU_H
CDU_M
CDU_LSK_3R
CDU_N
CDU_2
CDU_6
CDU_4
CDU_5
CDU_1
CDU_0
CDU_0
CDU_LSK_7L
CDU_E
CDU_0
CDU_5
CDU_5
CDU_5
CDU_3
CDU_4
CDU_5
CDU_0
CDU_LSK_9L
CDU_LSK_5L
CDU_LSK_5R
1. Entering Queue
2. Finishing Out of Loop
3. Remove Spinner
State: Preparing
Objects sent: 0
String was sent to UDP: AAP_PAGE 0
String was sent to UDP: CDU_CLR 1
String was sent to UDP: CDU_CLR 0
String was sent to UDP: CDU_LSK_7R 1
String was sent to UDP: CDU_LSK_7R 0
String was sent to UDP: CDU_Q 1
String was sent to UDP: CDU_Q 0
String was sent to UDP: CDU_E 1
Текст с пометкой 1,2,3 выполняется до того, как задача начнет отправлять текст. Счетчик 3. удаление текста должен быть последним. Мысли?
Комментарии:
1. Вы выполняете
sendMessageQueueToDCSBIOS
асинхронно, поэтому для него необходимо реализовать обратный вызов завершения и отправить счетчик остановки в основную очередь из этого обратного вызова.2. Спасибо. Есть ли обработчик завершения, встроенный в очередь отправки?