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

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

ただいまの
回答率

87.78%

セマフォがデットロック状態になる

受付中

回答 4

投稿 編集

  • 評価
  • クリップ 1
  • VIEW 1,880

score 14

firebaseで認証をしてからアプリを立ち上げたいのですが、セマフォで非同期処理である認証の完了を待とうとするとデッドロック状態になってしまいます。どうしてなのでしょうか?

 func application(_ application: UIApplication, didFinishLaunchingWithOptions launchOptions: [UIApplication.LaunchOptionsKey: Any]?) -> Bool {
           FirebaseApp.configure()
        let defaults = UserDefaults.standard
        defaults.register(defaults: ["firstlaunch":true])
        var a = DispatchSemaphore(value: 0)
        Auth.auth().signInAnonymously { (user, error) in
            print("ID:a\(user)")
            print(error)
            a.signal()
        }
        a.wait()
  • 気になる質問をクリップする

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

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

    クリップを取り消します

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

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

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

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

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

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

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

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

    質問の評価を下げる

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

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

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

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

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

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

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

    詳細な説明はこちら

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

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

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

回答 4

+2

こんにちは。
firebaseの事はわかりませんが、
Auth.auth().signInAnonymouslyが非同期で動作する、かつ完了時の関数がメインスレッドで呼び出されるようであれば、
メインスレッドのキューに処理が追加される→でもメインスレッドはa.waitで止まっているのでその処理が実行されることはない→デッドロック

という状況は有り得そうです。

投稿

  • 回答の評価を上げる

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

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

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

  • 回答の評価を下げる

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

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

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

  • 2019/08/19 14:45

    解決策はありますか?

    キャンセル

  • 2019/08/19 15:42

    考え方を変えてください。メインスレッドを止めない&セマフォを使わなければよいです。

    キャンセル

+1

print("ID:a\(user)")
print(error)
a.signal()


こちらは実行されていることは確認されているでしょうか?

Auth.auth().signInAnonymouslyのクロージャのスレッドが、
a.wait()で待っているスレッドと同じ場合は、クロージャへのスレッドがロックされているために
デッドロックとなります。

DispatchQueue.global().async {
Auth.auth().signInAnonymously { (user, error) in
            print("ID:a\(user)")
            print(error)
            a.signal()
        }
}


などとすると、別スレッドで実行されますので、a.signal()が実行されると思います。

投稿

  • 回答の評価を上げる

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

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

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

  • 回答の評価を下げる

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

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

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

0

コメントに書くべき内容ですがコメントではコードブロックが使えないので回答として記載させてください。内容としてはtakabosoftさん、k2moonsさんの回答を支持するもので、あくまで補足情報です。

firebase-ios-sdk/Firebase/Auth/Source/Auth/FIRAuth.m を見ると、signInAnonymouslyWithCompletion の処理は最終的に

dispatch_async(FIRAuthGlobalWorkQueue(), ^{
  // かなり中略...
  dispatch_async(dispatch_get_main_queue(), ^{
    callback(nil, error);
  });
}


で返ってきていますので、takabosoftさんが指摘する

Auth.auth().signInAnonymouslyが非同期で動作する、かつ完了時の関数がメインスレッドで呼び出されるようであれば、

は正のようです。
(FIRAuthGlobalWorkQueue の実装は → firebase-ios-sdk/Firebase/Auth/Source/Auth/FIRAuthGlobalWorkQueue.m)

投稿

  • 回答の評価を上げる

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

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

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

  • 回答の評価を下げる

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

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

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

  • 2019/08/20 11:29

    補足ありがとうございます👍

    キャンセル

0

ログインの状態を監視するAuthのメソッドaddStateDidChangeListener(_:)を利用してください。

リファレンス

投稿

  • 回答の評価を上げる

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

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

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

  • 回答の評価を下げる

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

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

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

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

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

関連した質問

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