使用DataSnapshot的
getChildrenCount()方法时,并不表示您正在遍历整个
DataSnapshot对象。相反,如果您使用的是DataSnapshot的
getChildren()方法,那么您正是在这样做。让我们举个例子,假设您有一个名为的节点
users,可以说拥有5000多名用户。
DatabaseReference rootRef = FirebaseDatabase.getInstance().getReference();DatabaseReference usersRef = rootRef.child("users");ValueEventListener valueEventListener = new ValueEventListener() { @Override public void onDataChange(DataSnapshot dataSnapshot) { long numberOfUsers = dataSnapshot.getChildrenCount(); // Count the number of users //This is called iteration for(DataSnapshot ds : dataSnapshot.getChildren()) { // Get user object on every iteration } } @Override public void onCancelled(@NonNull DatabaseError databaseError) {}};usersRef.addListenerForSinglevalueEvent(valueEventListener);
由于Firebase数据库中的每个节点都是a
Map,因此DataSnapshot也可以称为a
Map。
DataSnapshot实例包含Firebase数据库位置中的数据。每次读取数据库数据时,您都会以DataSnapshot的形式接收数据。
因此,如果要将
DataSnapshot对象强制转换为
Map,则以下代码行将非常好:
Map<String, Object> map = (Map<String, Object>) dataSnapshot;
因此调用
getChildrenCount()一个对
DataSnapshot对象就像调用
size()一个方法
Map,它在内部统计它所包含的对象的数量。
我在浪费阅读资源
对于新的Cloud Firestore数据库,此功能可用,其中根据您对Firestore数据库执行的CRUD *** 作数向您收费。如果您有兴趣,可以通过这种方法计算CloudFirestore中集合下的文档数。如您所见,除了经典的计数 *** 作外
+=,我们还有
task.getResult().size()。我还提到过,存储计数器的最佳实践是将它们存储在Firebase实时数据库中。因此,我认为,请继续进行此 *** 作并将其分别存储。
如果您认为应用程序将快速增长,那么另一种方法是,每次在您的节点中添加或删除用户时,都可以使用Cloud
Functions更新用户计数器
users。该技术适用于大型数据集。
并回答您的问题:
getChildrenCount()是否将我的用户的最新检索数量存储在某个地方?每次我运行我的应用以在每个孩子中用+
=进行计数时,getChildrenCount()是否都会执行?
如果您认为最新检索到的号码以某种方式存储在磁盘/内存中,则不会。每次打开应用程序时,
getChildrenCount()都会调用方法来获取最新的用户数。如果要实时获得该号码,则应在
users参考上附加一个侦听器。
欢迎分享,转载请注明来源:内存溢出
评论列表(0条)