FirebaseUI-Android RecyclerView でのスナップショット リスナーの追加と削除
FirebaseUI-Android は、RecyclerView にリアルタイム データを設定する便利な方法を提供します。ファイアーストア。ただし、リソース リークを避けるために、スナップショット リスナーを適切に追加および削除する方法を理解することが重要です。
スナップショット リスナーの追加
FirebaseRecyclerAdapter を使用する場合、リスナーはRecyclerView の各項目。 PopulateViewHolder メソッドでは、getRef(i) メソッドを使用して、現在の項目の DocumentReference を取得できます。
参照への変更をリッスンするには、addSnapshotListener(EventListener) メソッドを使用できます。このメソッドは引数として EventListener を取り、参照のスナップショットが変更されるたびに呼び出されます。
スナップショット リスナーの削除
リスナーを削除することが重要です。必要がなくなったとき。そうしないと、メモリ リークが発生します。 ListenerRegistration オブジェクトのremove() メソッドを使用してリスナーを削除できます。
populateViewHolder メソッドの実装
スナップショットを追加および削除する方法の例を次に示します。 FirebaseRecyclerAdapter の PopulateViewHolder メソッドのリスナー:
@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<DocumentSnapshot>() { @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 のremove() メソッドを呼び出すことができます。
@Override protected void onStop() { super.onStop(); if (listenerRegistration != null) { listenerRegistration.remove(); } }
次の手順に従うことで、スナップショット リスナーが確実に適切に追加および削除すると、リソース リークが防止され、アプリケーションのパフォーマンスが向上します。
以上がFirebaseUI-Android RecyclerView でスナップショット リスナーを使用するときにリソース リークを回避するにはどうすればよいですか?の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。