0

我过滤了查询,它返回大约 220 个项目,每个项目有 8 个字段,每个字段没有子节点。这不是一小部分数据,但绝对不是大数据。在下面的图片中会发生以下情况:

  1. Sec 25 - 用户点击加载数据,创建eventListener
  2. Sec 31 - 数据完全从 Firebase DB 加载
  3. 1 分钟 47 - 调用 onDataChange 并显示数据

我在调试器中看到了一些顶级进程:FirebaseDatabaseWorker。看起来它做了一些加载的数据处理。但是 30%CPU 的 1 分钟?是否可以优化?

谢谢!

在此处输入图像描述

final DatabaseReference artRef = 
database.getReference("sales/"+store+"/articles");
Query query = artRef.orderByChild("familyId").equalTo(familyId);

        query.addListenerForSingleValueEvent(new ValueEventListener() {
            @Override
            public void onDataChange(DataSnapshot snapshot) {
               for (DataSnapshot child : snapshot.getChildren()) {
                    Article article = child.getValue(Article.class);
                    article.id = Integer.parseInt(child.getKey());
                    articles.add(article);
                }

                adapter.notifyDataSetChanged();
            }
4

1 回答 1

0

在 Android Studio 中禁用 Instant Run 使得调用 onDataChange 的时间从 1 分钟缩短到 5 秒左右。

于 2017-04-03T16:42:54.777 回答