FirebaseUI-Android RecyclerView でのスナップショット リスナーの追加と削除
FirebaseUI-Android は、RecyclerView にリアルタイム データを設定する便利な方法を提供します。ファイアーストア。ただし、リソース リークを避けるために、スナップショット リスナーを適切に追加および削除する方法を理解することが重要です。
スナップショット リスナーの追加
FirebaseRecyclerAdapter を使用する場合、リスナーはRecyclerView の各項目。 PopulateViewHolder メソッドでは、getRef(i) メソッドを使用して、現在の項目の DocumentReference を取得できます。
参照への変更をリッスンするには、addSnapshotListener(EventListener) メソッドを使用できます。このメソッドは引数として EventListener を受け取り、参照のスナップショットが変更されるたびに呼び出されます。
スナップショット リスナーの削除
リスナーを削除することが重要です必要がなくなったとき。そうしないと、メモリ リークが発生します。 ListenerRegistration オブジェクトの Remove() メソッドを使用してリスナーを削除できます。
populateViewHolder メソッドの実装
スナップショットを追加および削除する方法の例を次に示します。 FirebaseRecyclerAdapter:
@Override protected void populateViewHolder(final ConvViewHolder convViewHolder, final Conv conv, int i) { final String list_user_id = getRef(i).getKey(); final DocumentReference docRef = db.collection("cities").document(list_user_id); ListenerRegistration listenerRegistration = null; if (listenerRegistration == null) { listenerRegistration = docRef.addSnapshotListener(new EventListener() { @Override public void onEvent(@Nullable DocumentSnapshot snapshot, @Nullable FirebaseFirestoreException e) { if (e != null) { Log.w(TAG, "Listen failed.", e); return; } if (snapshot != null && snapshot.exists()) { Log.d(TAG, "Current data: " snapshot.getData()); } else { Log.d(TAG, "Current data: null"); } } }); } }
この例では、listenerRegistration 変数は null として初期化されます。次に、if ステートメント内で、リスナーがまだ追加されていない場合は追加されます。
アクティビティ ライフサイクル メソッドでのリスナーの削除
次の場合にリスナーを削除します。アクティビティが表示されなくなった場合は、アクティビティの onStop() メソッドをオーバーライドして、listenerRegistration.
@Override protected void onStop() { super.onStop(); if (listenerRegistration != null) { listenerRegistration.remove(); } }
これらの手順に従うことで、スナップショット リスナーが適切に追加および削除され、リソース リークを防ぎ、アプリケーションのパフォーマンスを向上させることができます。
免責事項: 提供されるすべてのリソースの一部はインターネットからのものです。お客様の著作権またはその他の権利および利益の侵害がある場合は、詳細な理由を説明し、著作権または権利および利益の証拠を提出して、電子メール [email protected] に送信してください。 できるだけ早く対応させていただきます。
Copyright© 2022 湘ICP备2022001581号-3