Как прочитать этот символический журнал сбоев ios?

Apple отклонила новую версию приложения и отправила мне обратно журнал сбоев, мне трудно найти проблему, даже если журнал сбоев был обозначен в Xcode. Из следующего я предполагаю, что что-то не так в func getGameCenterScore в строке 246? Говорит ли это о большем количестве проблем?

Кстати, перед вызовом функции GameCenterScore() проверяется GKLocalPlayer.localPlayer().authenticated, но сеть не проверяется. Я должен думать, что это проблема здесь. Любое предложение?

Спасибо.

Exception Type:  EXC_BREAKPOINT (SIGTRAP)
Exception Codes: 0x0000000000000001, 0x0000000100054ef4
Triggered by Thread:  0

Thread 0 name:  Dispatch queue: com.apple.main-thread
Thread 0 Crashed:
0   xoxo                              0x0000000100054ef4 xoxo.ViewController.(getGameCenterScore (xoxo.ViewController) -> () -> Swift.Int).(closure #1) (ViewController.swift:246)
1   xoxo                              0x00000001000546b0 partial apply forwarder for reabstraction thunk helper from @callee_owned (@in ([Swift.AnyObject]!, ObjectiveC.NSError!)) -> (@out ()) to @callee_owned (@owned [Swift.AnyObject]!, @owned ObjectiveC.NSError!) -> (@unowned ()) with unmangled suffix "315" (ViewController.swift:0)
2   xoxo                              0x0000000100055110 reabstraction thunk helper from @callee_owned (@owned [Swift.AnyObject]!, @owned ObjectiveC.NSError!) -> (@unowned ()) to @callee_unowned @objc_block (@unowned ObjectiveC.NSArray!, @unowned ObjectiveC.NSError!) -> (@unowned ()) (ViewController.swift:0)
3   GameCenterFoundation              0x000000018e9de3a0 0x18e964000 + 500640
4   libdispatch.dylib                 0x0000000197841990 0x197840000 + 6544
5   libdispatch.dylib                 0x0000000197841950 0x197840000 + 6480
6   libdispatch.dylib                 0x0000000197846208 0x197840000 + 25096
7   CoreFoundation                    0x0000000185a877f4 0x1859a8000 + 915444
8   CoreFoundation                    0x0000000185a8589c 0x1859a8000 + 907420
9   CoreFoundation                    0x00000001859b12d0 0x1859a8000 + 37584
10  GraphicsServices                  0x000000018f09f6f8 0x18f094000 + 46840
11  UIKit                             0x000000018a576fa8 0x18a500000 + 487336
12  xoxo                              0x00000001000636c0 main (AppDelegate.swift:12)
13  libdyld.dylib                     0x000000019786ea04 0x19786c000 + 10756

func getGameCenterScore(){
    var gameCenterScore = 0
    let leaderBoardRequest = GKLeaderboard()
    leaderBoardRequest.identifier = "XXXXXXXXXXXXX"

    leaderBoardRequest.loadScoresWithCompletionHandler { (scores, error) -> Void in
        if (error != nil) {
            println("Error: \(error!.localizedDescription)")
        } else if (scores != nil) {
            let localPlayerScore = leaderBoardRequest.localPlayerScore
            gameCenterScore = Int(localPlayerScore.value)

            if self.saveData.stringForKey("topScore") == nil {
                self.saveData.setValue(gameCenterScore, forKey: "topScore")
                self.topScoreLabel.text = "\(gameCenterScore)"
            }else{
                if gameCenterScore > self.saveData.integerForKey("topScore"){
                    self.saveData.setValue(gameCenterScore, forKey: "topScore")
                    self.topScoreLabel.text = "\(gameCenterScore)" // line 246
                }
            }

        }
    }
}

person jdleung    schedule 05.05.2015    source источник
comment
Пожалуйста, опубликуйте код для этой функции: getGameCenterScore.   -  person pteofil    schedule 05.05.2015
comment
@pteofil, опубликована функция и отмечена строка 246. Спасибо.   -  person jdleung    schedule 05.05.2015


Ответы (1)


Только что прошел через то же самое. Бинарный отказ для моего загруженного приложения. Наконец-то его приняли. Я нашел номер строки так же, как и вы. (Я использовал textWrangler и сравнил символический текст с исходным сбоем. И это могла быть только одна строка. Очень похоже на ваш 216.) Строки, указанные как swift:0, находятся после строки, вызвавшей сбой.

Чтобы решить или устранить проблему: 1) Я обнаружил, что призраки могут задерживаться в моем быстром коде. Очистить и восстановить. Попробуйте переместить код. 2) Обратите внимание, что строка, в которой указан сбой, может отличаться на несколько строк. Строка, которую они указали для моего приложения, была комментарием. Ошибка была в коде выше, и этот код выглядел нормально. Я решил это, переписав по-другому. 3) Посмотрите внимательно на свой код.

if gameCenterScore > self.saveData.integerForKey("topScore"){`enter code here`

Это вылетит, если ваш gameCenterScore == topScore?

person Mountain Man    schedule 10.06.2016