首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >Android UsageStatsManager产生错误的输出?

Android UsageStatsManager产生错误的输出?
EN

Stack Overflow用户
提问于 2015-05-22 01:02:05
回答 2查看 5.7K关注 0票数 7

我正在使用这个link来生成应用程序使用状态。我对所选间隔的理解是,对于YEARLY间隔,它为beginTimeendTime持续时间之间的每个包聚合每个YEAR的数据。类似地,它应该适用于WEEKLYDAILY间隔。

使用WEEKLY,我的代码和输出如下所示;

代码:

代码语言:javascript
复制
Calendar beginCal = Calendar.getInstance();
beginCal.set(Calendar.DATE, 1);
beginCal.set(Calendar.MONTH, 0);
beginCal.set(Calendar.YEAR, 2012);

Calendar endCall = Calendar.getInstance();
endCall.set(Calendar.DATE, 1);
endCall.set(Calendar.MONTH, 0);
endCall.set(Calendar.YEAR, 2016);

final List<UsageStats> queryUsagesStats= mUsageStatsManager.queryUsageStats(UsageStatsManager.INTERVAL_WEEKLY, beginCal.getTimeInMillis(), endCall.getTimeInMillis());    

for(UsageStats us: queryUsagesStats)
{
    long beginTime = us.getFirstTimeStamp();
    String beginDate = df.format(new Date(beginTime));


    long endTime = us.getLastTimeStamp();
    String endDate = df.format(new Date(endTime));
    String lastTime = df.format(new Date(us.getLastTimeUsed()));
    long totalTimeInForeground = us.getTotalTimeInForeground()/1000L;
    System.out.println("Pkg = " + us.getPackageName() + ", beginTime " + beginDate + ", endTime= " + endDate + ", lastTime = " + lastTime + ", totalTime = " + totalTimeInForeground);
}

产出:

代码语言:javascript
复制
Pkg = com.example.newappusagestatistics, beginTime 05/20/2015 17:00:04, endTime= 05/21/2015 17:55:42, lastTime = 05/21/2015 17:55:42, totalTime = 11186
Pkg = com.android.launcher, beginTime 05/20/2015 17:00:04, endTime= 05/21/2015 17:55:42, lastTime = 05/21/2015 17:55:42, totalTime = 1091
Pkg = com.android.browser, beginTime 05/20/2015 17:00:04, endTime= 05/21/2015 17:15:27, lastTime = 05/21/2015 17:15:27, totalTime = 68
Pkg = com.android.sdksetup, beginTime 05/20/2015 17:00:04, endTime= 01/01/1970 15:59:55, lastTime = 05/21/2015 14:41:08, totalTime = 1194
Pkg = com.android.camera, beginTime 05/20/2015 17:00:04, endTime= 01/01/1970 15:59:55, lastTime = 05/21/2015 14:55:32, totalTime = 40
Pkg = com.android.settings, beginTime 05/20/2015 17:00:04, endTime= 01/01/1970 15:59:55, lastTime = 05/21/2015 16:15:19, totalTime = 97
Pkg = com.android.systemui, beginTime 05/20/2015 17:00:04, endTime= 01/01/1970 15:59:55, lastTime = 05/21/2015 14:47:45, totalTime = 

但是,如果对上面的代码使用INTERVAL.DAILY,我只会得到前三行。我的间隔足够大,它应该包含这个间隔之间所有包的所有数据。

代码语言:javascript
复制
Pkg = com.example.newappusagestatistics, beginTime 05/21/2015 17:00:00, endTime= 05/21/2015 17:59:18, lastTime = 05/21/2015 17:59:18, totalTime = 3484
Pkg = com.android.launcher, beginTime 05/21/2015 17:00:00, endTime= 05/21/2015 17:59:18, lastTime = 05/21/2015 17:59:18, totalTime = 27
Pkg = com.android.browser, beginTime 05/21/2015 17:00:00, endTime= 05/21/2015 17:15:27, lastTime = 05/21/2015 17:15:27, totalTime = 43

我是不是做错了什么或者我对聚合间隔的理解是不正确的?任何帮助都将不胜感激。谢谢。

Edit1

在查看了android存储在/data/system/usagestats文件夹中的statsfile之后,我发现了两个用于每日统计的文件和一个用于每周统计的文件,如下所示。

每日file1

代码语言:javascript
复制
<usagestats version="1" endTime="59366071">
<packages>
<package lastTimeActive="59366071" package="com.example.newappusagestatistics" timeActive="4064908" lastEvent="1"/>
<package lastTimeActive="59366020" package="com.android.launcher" timeActive="813728" lastEvent="2"/>
<package lastTimeActive="927475" package="com.android.browser" timeActive="43838" lastEvent="2"/>
</packages>

每日file2

代码语言:javascript
复制
<usagestats version="1" endTime="86395657">
    <packages>
        <package lastTimeActive="86395657" package="com.example.newappusagestatistics" timeActive="7916365" lastEvent="3" />
        <package lastTimeActive="85743386" package="com.android.launcher" timeActive="1064651" lastEvent="2" />
        <package lastTimeActive="78961499" package="com.android.browser" timeActive="24715" lastEvent="2" />
        <package lastTimeActive="78063875" package="com.android.sdksetup" timeActive="1194161" lastEvent="3" />
        <package lastTimeActive="78928555" package="com.android.camera" timeActive="40775" lastEvent="2" />
        <package lastTimeActive="83715390" package="com.android.settings" timeActive="97012" lastEvent="2" />
        <package lastTimeActive="78461328" package="com.android.systemui" timeActive="4162" lastEvent="2" />
    </packages>

每周一次

代码语言:javascript
复制
<usagestats version="1" endTime="145761729">
    <packages>
        <package lastTimeActive="145761729" package="com.example.newappusagestatistics" timeActive="11981273" lastEvent="1" />
        <package lastTimeActive="145761678" package="com.android.launcher" timeActive="1878379" lastEvent="2" />
        <package lastTimeActive="87323133" package="com.android.browser" timeActive="68553" lastEvent="2" />
        <package lastTimeActive="78063875" package="com.android.sdksetup" timeActive="1194161" lastEvent="3" />
        <package lastTimeActive="78928555" package="com.android.camera" timeActive="40775" lastEvent="2" />
        <package lastTimeActive="83715390" package="com.android.settings" timeActive="97012" lastEvent="2" />
        <package lastTimeActive="78461328" package="com.android.systemui" timeActive="4162" lastEvent="2" />
    </packages>

整个数据似乎都搞砸了。对于同一个浏览器应用程序,每日存储不同的结果,每周存储不同的结果。

EN

回答 2

Stack Overflow用户

发布于 2016-05-04 07:11:17

根据谷歌发布的文档。

(https://developer.android.com/about/versions/android-5.0.html#System)

该系统在每个应用程序的基础上收集使用数据,将数据汇总在每天、每周、每月和每年的间隔内。系统保存此数据的最长期限如下:

每日数据:7天

周刊数据:4周

月数据:6个月

年度数据:2年

如果您想获得7天以上的统计数据,请更改从INTERVAL_DAILY到INTERVAL_WEEKLY或INTERVAL_YEARLY的时间间隔。这里有更多关于同样的细节。

https://developer.android.com/reference/android/app/usage/UsageStatsManager.html

票数 10
EN

Stack Overflow用户

发布于 2015-11-01 16:06:07

可能是搞砸了。您不能相信queryUsageStats的结果。

在我的例子中,

代码语言:javascript
复制
queryUsageStats(UsageStatsManager.INTERVAL_DAILY, 0, today) 

显示过去七天的结果,并调用

代码语言:javascript
复制
queryUsageStats(UsageStatsManager.INTERVAL_DAILY, few-days-ago, today) 

只显示今天的结果。几天前和今天是以毫秒为单位的指定日期.检查今天的结果显示,某个应用程序的使用缺失了,而今天晚些时候使用的其他应用程序也出现了。

票数 3
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/30386789

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档