使用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数据库中的每个节点都是aMap
,因此DataSnapshot也可以称为aMap
。
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
参考上附加一个侦听器。