Я новичок в Swift и способ синхронизации / асинхронной загрузки файла.
У меня есть большой JSON-файл на локальном компьютере для приложения iPad
о футболе со списком и статистикой футболистов.
На данный момент я загружаю весь список игроков внутри массива словарей
и я позволяю пользователю искать конкретного игрока
func loadJSON() {
/// Load Json File
if let path = Bundle.main.path(forResource: "players", ofType: "json") {
do {
let data = try Data(contentsOf: URL(fileURLWithPath: path), options: .alwaysMapped)
let jsonObj = try JSON(data: data)
/// For Player in JSON Serialize values
for (_,subJson):(String, JSON) in jsonObj["PackData"]["PlayerData"]["P"] {
let firstName = subJson["_f"].stringValue
let lastName = subJson["_s"].stringValue
let id = subJson["_id"].stringValue
let dateOfBirth = subJson["_d"].stringValue
let height = subJson["_h"].stringValue
let weight = subJson["_w"].stringValue
let image = subJson["_i"].stringValue
let player = Player(id: id, firstName: firstName, lastName: lastName, dateOfBirth: dateOfBirth, height: height, weight: weight, image: image)
/// Append Player in players Array
players.append(player)
}
Поскольку я использую loadJSON()
в ViewDidLoad
, приложение останавливается на несколько секунд и использует много памяти при переходе к этому представлению.
Как правильно обрабатывать / реализовывать что-то вроде поиска в БД в асинхронном режиме?
EDIT:
Я уже пытался использовать диспетчер DispatchQueue.global(qos: .background).async
, но я получаю сообщение об ошибке: indexPath.row out of range
на player = filteredPlayers[indexPath.row]
// create a cell for each table view row
func tableView(_ tableView: UITableView, cellForRowAt indexPath: IndexPath) -> UITableViewCell {
// create a new cell if needed or reuse an old one
let cell:UITableViewCell = self.searchTableView.dequeueReusableCell(withIdentifier: cellReuseIdentifier) as UITableViewCell!
let player: Player
/// Return a different table if is searching or not
if isFiltering() {
player = filteredPlayers[indexPath.row]
} else {
player = players[indexPath.row]
}
cell.textLabel?.text = player.firstName! + " " + player.lastName!
cell.textLabel?.textColor = UIColor.white
return cell
}