Быстрый счетчик, исчезающий до завершения задачи очереди

#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. Спасибо. Есть ли обработчик завершения, встроенный в очередь отправки?