Доступ к переменной за пределами данной функции

Я попробовал обработчик завершения, как предложил Гурдев, и кое-что получил. Он возвращает значения моего массива в функции MAIN. Но проблема та же: мне нужно использовать функцию Sleep() в течение 3 секунд, чтобы завершить HTTP-запрос. Это похоже на жесткое кодирование, поскольку для его завершения может потребоваться меньше или больше 3 секунд. Когда я удаляю команду Sleep(), я возвращаю массив VOID.

Соответствующий код указан ниже.

Спасибо!

  --------Web Class--------
  import Foundation
  import UIKit

  class Web {

      var ar1 = [Double]()

      var ar2 = [Double]()

      func getData(str: String, completion: (_ result: [[Double]]) -> Void) {

    let request = NSMutableURLRequest(url: URL(string: str)!)

    httpGet(request as URLRequest!){
        (data, error) -> Void in
        if error != nil {
            print(error ?? "Error")
        } else {
            let delimiter = "\t"
            let lines:[String] = data.components(separatedBy: CharacterSet.newlines) as [String]

        for line in lines {
                var values:[String] = []
                if line != "" {
                    values = line.components(separatedBy: delimiter)
                    let str1 = (values[0])//FIRST COLUMN
                    let str2 = (values[1])//SECOND COLUMN
                    let db1 = NumberFormatter().number(from: str1)?.doubleValue
                    self.ar1.append(db1!)
                    let db2 = NumberFormatter().number(from: str2)?.doubleValue
                    self.ar2.append(db2!)

                }

            }

        }

    }//end of request

  sleep(3) // This delay sends data to MAIN, Otherwise NOT

  let dta = [self.ar1, self.ar2]

  completion(dta)

   }

  func httpGet(_ request: URLRequest!, callback: @escaping (String, String?) -> Void) {
     let session = URLSession.shared
    let task = session.dataTask(with: request, completionHandler: {
        (data, response, error) -> Void in
        if error != nil {
            callback("", error!.localizedDescription)
        } else {
            let result = NSString(data: data!, encoding:
                String.Encoding.ascii.rawValue)!
            callback(result as String, nil)
        }
      })
      task.resume()
   }

} -------- Веб-класс --------

-------Call In Class--------
 Web().getData (str:   "https://dl.dropboxusercontent.com/s/f6j7w7zeqaavzqw/s02.txt?dl=0")
        {
        (result: [[Double]]) in

            let x = result[0]
            let y = result[1]
 }
-------Call In Class--------

По сути, я пытаюсь получить доступ к моей переменной "ar1" в определенный момент в моем коде, но я не могу. Я пытаюсь вернуть значение тоже, но он возвращает NULL в этой точке.

Что здесь не так?

Я попробовал как приведенный ниже код:

import Foundation
import UIKit

class Web {
    var ar1 = [Double]()
    var ar2 = [Double]()

    func getData(str: String) -> [Double] {
    let request = NSMutableURLRequest(url: URL(string: str)!)
      httpGet(request as URLRequest!){
            (data, error) -> Void in
            if error != nil {
                print(error ?? "Error")
            } else {
                let delimiter = "\t"
                let lines:[String] = data.components(separatedBy:     CharacterSet.newlines) as [String]

                for line in lines {           
                    var values:[String] = []
                    if line != "" {
                        values = line.components(separatedBy: delimiter)
                         let str1 = (values[0])//FIRST COLUMN
                        let str2 = (values[1])//SECOND COLUMN
                       let db1 = NumberFormatter().number(from: str1)?.doubleValue
                        self.ar1.append(db1!)
                        let db2 = NumberFormatter().number(from: str2)?.doubleValue
                        self.ar2.append(db2!)
                    }
                }
            dump (self.ar1) // "ar1" accessible HERE (returns all elements)
        }
    }//end of request
        //BUT I WANT TO RETURN "ar1" HERE !
       // So that I can use it in my MAIN class
        dump (self.ar1) // "ar1" not accessible here (returns ZERO elements)
        return self.ar1
    }
        func httpGet(_ request: URLRequest!, callback: @escaping (String, String?) -> Void) {
            let session = URLSession.shared
            let task = session.dataTask(with: request, completionHandler: {
                (data, response, error) -> Void in
                if error != nil {
                callback("", error!.localizedDescription)
                } else {
                let result = NSString(data: data!, encoding:
                    String.Encoding.ascii.rawValue)!
                callback(result as String, nil)
                }
            })
            task.resume()
}
    }

1 ответ

Решение

В вашем коде вы возвращаете ar1 из оператора возврата вашего метода, тогда как значение ar1 устанавливается в обработчике завершения Aysnchronous callback. Вы должны использовать блок обработчика завершения, где вы пытаетесь получить доступ к значению ar1, Функция HTTPGet работает в асинхронном режиме и значение в ar1 устанавливается в блоке обработчика обратного вызова.

Дайте мне знать, если вам нужна дополнительная помощь по этому вопросу.

Другие вопросы по тегам