質問をすることでしか得られない、回答やアドバイスがある。

15分調べてもわからないことは、質問しよう!

ただいまの
回答率

89.09%

libc++abi.dylib: terminating with uncaught exception of type NSExceptionが実機でのみ発生する

解決済

回答 2

投稿 編集

  • 評価
  • クリップ 0
  • VIEW 2,309

naokun

score 13

イメージ説明
コードを書き終わり、シミュレーターでの実行も成功したので自分の端末にインストールしようとしたらこの様なエラーが発生しました。何回か類似するもの(Storyboard上での関連付け問題)を見た事があったので真っ先にチェックしましたが何の問題もありませんでした(よくよく考えるとそれならSimulatorでも発生する)。ボタンを押した後にクラッシュするので恐らく処理に使っているUIImagePickerControllerの問題だと思うのですが何故シミュレーターでは問題なく動作するのでしょうか?何方か教えてください。

//コードの一部を載せておきます
    @IBAction func loadFile(_: Any) {
        openPicker(sourceType: UIImagePickerControllerSourceType.photoLibrary)
    }

    func openPicker(sourceType: UIImagePickerControllerSourceType) {
        if !UIImagePickerController.isSourceTypeAvailable(sourceType) {
            showAlert(title: "フォトライブラリ", text: "アクセスできません")
            return
        }
        let picker = UIImagePickerController()
        print("1")
        picker.sourceType = sourceType
        print("2")
        picker.delegate = self
        print("3")
        present(picker, animated: false, completion: nil)
    }

    func imagePickerController(_ picker: UIImagePickerController, didFinishPickingMediaWithInfo info: [String : Any]) {
        print("4")
        //この4がログにないのでこの動作が始まる前にクラッシュしていると思われる
        let image = info[UIImagePickerControllerOriginalImage] as! UIImage
        picker.presentingViewController?.dismiss(animated: true, completion: nil)
    }

bt出力の結果〜

  • thread #1, queue = 'com.apple.main-thread', stop reason = signal SIGABRT
    frame #0: 0x0000000190cf1014 libsystem_kernel.dylib__pthread_kill + 8     frame #1: 0x0000000190dbb264 libsystem_pthread.dylibpthread_kill + 112
    frame #2: 0x0000000190c659c4 libsystem_c.dylibabort + 140     frame #3: 0x00000001907311b0 libc++abi.dylibabort_message + 132
    frame #4: 0x000000019074ac04 libc++abi.dylibdefault_terminate_handler() + 304     frame #5: 0x0000000190758820 libobjc.A.dylib_objc_terminate() + 124
    frame #6: 0x00000001907475d4 libc++abi.dylibstd::__terminate(void (*)()) + 16     frame #7: 0x00000001907471a8 libc++abi.dylib__cxa_rethrow + 144
    frame #8: 0x00000001907586f8 libobjc.A.dylibobjc_exception_rethrow + 44     frame #9: 0x0000000191bd2e10 CoreFoundationCFRunLoopRunSpecific + 532
    frame #10: 0x000000019363c074 GraphicsServicesGSEventRunModal + 100     frame #11: 0x0000000197e8d058 UIKitUIApplicationMain + 208
  • frame #12: 0x000000010005d0d0 appnamemain at AppDelegate.swift:12     frame #13: 0x0000000190be159c libdyld.dylibstart + 4

*シミュレーターでは予想していた様に動いたので端末関連の問題かもしれないんですけど、既に二台試しましたが同じ結果に収まりました。
*Github: https://github.com/narry0966/0xBF

  • 気になる質問をクリップする

    クリップした質問は、後からいつでもマイページで確認できます。

    またクリップした質問に回答があった際、通知やメールを受け取ることができます。

    クリップを取り消します

  • 良い質問の評価を上げる

    以下のような質問は評価を上げましょう

    • 質問内容が明確
    • 自分も答えを知りたい
    • 質問者以外のユーザにも役立つ

    評価が高い質問は、TOPページの「注目」タブのフィードに表示されやすくなります。

    質問の評価を上げたことを取り消します

  • 評価を下げられる数の上限に達しました

    評価を下げることができません

    • 1日5回まで評価を下げられます
    • 1日に1ユーザに対して2回まで評価を下げられます

    質問の評価を下げる

    teratailでは下記のような質問を「具体的に困っていることがない質問」、「サイトポリシーに違反する質問」と定義し、推奨していません。

    • プログラミングに関係のない質問
    • やってほしいことだけを記載した丸投げの質問
    • 問題・課題が含まれていない質問
    • 意図的に内容が抹消された質問
    • 過去に投稿した質問と同じ内容の質問
    • 広告と受け取られるような投稿

    評価が下がると、TOPページの「アクティブ」「注目」タブのフィードに表示されにくくなります。

    質問の評価を下げたことを取り消します

    この機能は開放されていません

    評価を下げる条件を満たしてません

    評価を下げる理由を選択してください

    詳細な説明はこちら

    上記に当てはまらず、質問内容が明確になっていない質問には「情報の追加・修正依頼」機能からコメントをしてください。

    質問の評価を下げる機能の利用条件

    この機能を利用するためには、以下の事項を行う必要があります。

質問への追記・修正、ベストアンサー選択の依頼

  • fuzzball

    2018/03/11 02:35 編集

    「ボタンを押した後」は何のボタンでしょうか?あと、止まった後にConsoleで bt と入力して出力を教えて下さい。

    キャンセル

  • naokun

    2018/03/11 09:20 編集

    @IBAction func loadFileです、出力は* thread #1, queue = 'com.apple.main-thread', stop reason = signal SIGABRT frame #0: 0x0000000190cf1014 libsystem_kernel.dylib`__pthread_kill + 8 frame #1: 0x0000000190dbb264 libsystem_pthread.dylib`pthread_kill + 112 frame #2: 0x0000000190c659c4 libsystem_c.dylib`abort + 140 frame #3: 0x00000001907311b0 libc++abi.dylib`abort_message + 132 frame #4: 0x000000019074ac04 libc++abi.dylib`default_terminate_handler() + 304 frame #5: 0x0000000190758820 libobjc.A.dylib`_objc_terminate() + 124 frame #6: 0x00000001907475d4 libc++abi.dylib`std::__terminate(void (*)()) + 16 frame #7: 0x00000001907471a8 libc++abi.dylib`__cxa_rethrow + 144 frame #8: 0x00000001907586f8 libobjc.A.dylib`objc_exception_rethrow + 44 frame #9: 0x0000000191bd2e10 CoreFoundation`CFRunLoopRunSpecific + 532 frame #10: 0x000000019363c074 GraphicsServices`GSEventRunModal + 100 frame #11: 0x0000000197e8d058 UIKit`UIApplicationMain + 208 * frame #12: 0x000000010005d0d0 appname`main at AppDelegate.swift:12 frame #13: 0x0000000190be159c libdyld.dylib`start + 4でした

    キャンセル

  • naokun

    2018/03/11 11:46

    行き詰まってる感じなのでgithubにあげます〜https://github.com/narry0966/0xBF〜見ていただけると嬉しいです

    キャンセル

  • fuzzball

    2018/03/12 10:16

    解決したのであればcloseして下さい。

    キャンセル

回答 2

0

https://teratail.com/questions/103154
ここと同様の症状ではないでしょうか?

投稿

  • 回答の評価を上げる

    以下のような回答は評価を上げましょう

    • 正しい回答
    • わかりやすい回答
    • ためになる回答

    評価が高い回答ほどページの上位に表示されます。

  • 回答の評価を下げる

    下記のような回答は推奨されていません。

    • 間違っている回答
    • 質問の回答になっていない投稿
    • スパムや攻撃的な表現を用いた投稿

    評価を下げる際はその理由を明確に伝え、適切な回答に修正してもらいましょう。

  • 2018/03/11 01:57

    全ての動作の関連付けを外してもう一度やりましたが、治っていないので違うかと

    キャンセル

  • 2018/03/11 02:02

    presentではなく、self.presentViewControllerではダメですか?

    キャンセル

  • 2018/03/11 09:21

    ダメでした.......というかpresentViewControllerにするとpresentに直せってエラーが出ますね

    キャンセル

  • 2018/03/11 11:48

    Githubにファイルを全てアップロードしました。お時間があれば見てください。
    https://github.com/narry0966/0xBF

    キャンセル

checkベストアンサー

-1

info.plistに下記の設定はしていますでしょうか?

Privacy – Photo Library Additions Usage Description

権限が足りていないのかなと思いました。

投稿

  • 回答の評価を上げる

    以下のような回答は評価を上げましょう

    • 正しい回答
    • わかりやすい回答
    • ためになる回答

    評価が高い回答ほどページの上位に表示されます。

  • 回答の評価を下げる

    下記のような回答は推奨されていません。

    • 間違っている回答
    • 質問の回答になっていない投稿
    • スパムや攻撃的な表現を用いた投稿

    評価を下げる際はその理由を明確に伝え、適切な回答に修正してもらいましょう。

  • 2018/03/11 11:45

    ダメでした、試しにBreakpointをdisableにしましたが変わりなく、Xcodeから外しても効果なしです

    キャンセル

  • 2018/03/11 11:48

    Githubにファイルを全てアップロードしました。お時間があれば見てください。
    https://github.com/narry0966/0xBF

    キャンセル

  • 2018/03/11 13:09

    ダウンロードしてやってみましたが、私の環境ではprint("4")は出力されました。
    端末からアプリを一度アンインストールしたり、XcodeのDerivedDataの削除などやってみたらどうでしょうか?

    キャンセル

15分調べてもわからないことは、teratailで質問しよう!

  • ただいまの回答率 89.09%
  • 質問をまとめることで、思考を整理して素早く解決
  • テンプレート機能で、簡単に質問をまとめられる

同じタグがついた質問を見る