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

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

新規登録して質問してみよう
ただいま回答率
85.46%
Cloud Firestore

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

Swift

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

Q&A

0回答

811閲覧

SwiftでCould not reach Cloud Firestore backend. Backend didn't respond within 10 seconds.

ozkdev

総合スコア0

Cloud Firestore

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

Swift

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

0グッド

0クリップ

投稿2021/05/30 09:15

Firestoreから取得したデータを画面にカテゴリーごとに表示したいです。
カテゴリーごとに並び替えを実行するまでにFirestoreが読み込みを完了していたい為、
DispatchSemaphoreを入れ処理を実行しましたが、以下エラーが発生し解決策がわかりません。

「Could not reach Cloud Firestore backend. Backend didn't respond within 10 seconds.」

問題点、解決先のご教示願います。

func load() -> [itemData] { var datas: [itemData] = [] var semaphore : DispatchSemaphore! let db = Firestore.firestore() semaphore = DispatchSemaphore(value: 0) db.collection("paper").getDocuments() { (snaps, error) in if let error = error { fatalError("(error)") } guard let snapshot = snaps else { return } for document in snapshot.documents { let item = document.data() datas += [itemData( id:item["id"] as! Int, name: item["name"] as! String, photo: item["photo"] as! String, kind: item["kind"] as! Int, category: item["category"] as! String] } semaphore.signal() //print(datas) } print("semaphore wait...") semaphore.wait() print("complete!") return datas }

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

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

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

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

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

hoshi-takanori

2021/05/30 09:57

DispatchSemaphore なんか使わずに非同期処理しましょう。
ozkdev

2021/05/30 13:11

ありがとう御座います。 同期を取ろうとした理由が、表示する際に  @EnvironmentObjectで定義し、以下処理でエラーになります。 var categories: [String: [ItemData]] { Dictionary( grouping: Datas, by: { $0.category } ) } Categoryでグルーピングしたいので、同期とる以外によい方法はありますでしょうか
hoshi-takanori

2021/05/30 18:08

その categories が ObservableObject のサブクラスの @Published var ってことなら、初期値を空または nil にしておいて、非同期の結果が返ってきたら更新すれば良いかと。
ozkdev

2021/05/31 14:59

ありがとう御座います。 エラーがなくなりました。ただデータが表示できません。 どうも、上記記載のソースコード db.collection("paper").getDocuments() { (snaps, error) in  内ではprint(datas)でデータは入りますが、returnを通らずに元々の参照側 @Published var itemList: [itemData] = load() ItemListは空データのままになっています。 ご教示願います。
hoshi-takanori

2021/05/31 17:35

load メソッドというか、その中で呼んでる getDocuments は、Firestore にリクエストを投げるだけで、結果を待たずに return するため、load メソッド自体も空データのまま return します。 その後、Firestore から結果が帰ってきたら getDocuments() の後ろのクロージャ { (snaps, error) in 〜 } が実行されますので、この中で改めて itemList の値を更新すると良いでしょう。
ozkdev

2021/06/02 00:51

解決いたしました、ありがとう御座いました。
guest

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

まだ回答がついていません

会員登録して回答してみよう

アカウントをお持ちの方は

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

ただいまの回答率
85.46%

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

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

質問する

関連した質問