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

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

新規登録して質問してみよう
ただいま回答率
85.50%
Firebase

Firebaseは、Googleが提供するBasSサービスの一つ。リアルタイム通知可能、並びにアクセス制御ができるオブジェクトデータベース機能を備えます。さらに認証機能、アプリケーションのログ解析機能などの利用も可能です。

Cloud Firestore

Cloud Firestore は、自動スケーリングと高性能を実現し、アプリケーション開発を簡素化するように構築された NoSQLドキュメントデータベースです。

Swift

Swiftは、アップルのiOSおよびOS Xのためのプログラミング言語で、Objective-CやObjective-C++と共存することが意図されています

Q&A

解決済

2回答

1109閲覧

非同期処理の直列実行

makemake

総合スコア7

Firebase

Firebaseは、Googleが提供するBasSサービスの一つ。リアルタイム通知可能、並びにアクセス制御ができるオブジェクトデータベース機能を備えます。さらに認証機能、アプリケーションのログ解析機能などの利用も可能です。

Cloud Firestore

Cloud Firestore は、自動スケーリングと高性能を実現し、アプリケーション開発を簡素化するように構築された NoSQLドキュメントデータベースです。

Swift

Swiftは、アップルのiOSおよびOS Xのためのプログラミング言語で、Objective-CやObjective-C++と共存することが意図されています

0グッド

0クリップ

投稿2020/03/23 14:20

前提・実現したいこと

swiftとFirebaseでSNS機能を実装中です。
アカウント削除を実装しており、
投稿したデータ、フォローリスト、フォロワーリスト、プロフィールの削除が完了した後にアカウントの削除を実行させようとしています。
dispatchgroupを作成し、enterで開始、leaveで完了を管理し、leaveとなったタイミングでnotifyで指定したメソッドを実行させています。

発生している問題

結果として、削除自体は全て完了するのですが、デバックを確認すると、 notifyで指定したアカウント削除メソッドが、他のメソッドの完了を待つことなく実行されてしまいます。

該当のソースコード

func deleteAll() { let dispatchGroup = DispatchGroup() let dispatchQueue = DispatchQueue(label: "queue") dispatchGroup.enter() dispatchQueue.async(group: dispatchGroup) { [weak self] in             //①ここでFirestoreにあるデータを削除 self!.deleteUserData() self!.deleteFollow() self!.deleteFollower() self!.deleteData()             dispatchGroup.leave() } dispatchGroup.notify(queue: .main) { //①のメソッドが全て完了した後、アカウントを削除(AuthenticationのUser) self.deleteAccount() } }

試したこと

leaveさせるタイミングを変更してみましたが結果は変わりません。

補足情報(FW/ツールのバージョンなど)

https://qiita.com/shtnkgm/items/d9b78365a12b08d5bde1 を参考にさせていただきました。

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

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

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

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

MasakiHori

2020/03/23 16:23

deleteUserData()などが内部で別のスレッドを起動していた場合はうまくいきません deleteUserData()などはどのようになっていますか?
makemake

2020/03/23 18:03 編集

コメントいただき誠にありがとうございます。 deleteUserData()では、 func deleteUserData() { let userRef = self.userID db.collection("user").document(userRef).delete() { (error) in if error == nil {    print("アカウントデータ削除成功") }else{     print("アカウントデータ削除失敗")   }      }    } のようになっており、他もfirebaseとの通信を行い、データを取得し、deleteするようになっております。また、全てメインキューで実行されています。 ご回答何卒よろしくお願いいたします。
guest

回答2

0

ベストアンサー

delete(completion:)が非同期で動いているのでそこを同期化する必要があります。

swift

1func deleteUserDataSync() { 2 3 let semaphore = DispatchSemaphore(value: 0) 4 let userRef = self.userID 5 db.collection("user").document(userRef).delete() { (error) in 6 if error == nil { 7 print("アカウントデータ削除成功") 8 }else{ 9 print("アカウントデータ削除失敗") 10 } 11 12 13 semaphore.signal() 14 } 15 16 semaphore.wait() 17}

Firestoreの操作系メソッドはすべて非同期なので他も同様に変更してください。

投稿2020/03/24 00:17

MasakiHori

総合スコア3384

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

makemake

2020/03/24 14:12

ご回答いただき誠にありがとうございます! 教えていただいた通り、それぞれのメソッドを同期化したら、期待した順番通りに実行されました! セマフォや同期・非同期処理についてもとても勉強になりました! さらに自分でも知見を深めていきます! 本当に感謝です!ありがとうございます!
guest

0

下記が参考になるかわかりませんが、書き方の問題なのかも。

Swiftで非同期処理時、後処理をしたい

投稿2020/03/23 14:40

freemann

総合スコア264

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

makemake

2020/03/23 18:13

参考URLご教授いただき誠にありがとうございます。参考URL記載の通りの記述であれば期待する順番通りになるので、入れ込んでいるメソッドが原因かもしれません、、、今一度見直してみます!
guest

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

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

ただいまの回答率
85.50%

質問をまとめることで
思考を整理して素早く解決

テンプレート機能で
簡単に質問をまとめる

質問する

関連した質問