Я получаю разные startTimestamp и endtimestamp, которые я предоставил в методе networkstatsmanager.querydetailsforuid (). Как это решить? - PullRequest
0 голосов
/ 25 апреля 2020

Получение разного времени начала и окончания, которое я предоставляю в NetworkStatsManager.queryDetailsForUid Вот мой фрагмент кода:

Я хочу получить данные об использовании приложения в интервале времени начала и времени окончания, когда я вызываю метод и передача даты начала и окончания из календаря в миллисекундах, но после вызова queryDetailsForUid() он показывает другое время:

Calendar cal1 = Calendar.getInstance();
Date end = cal1.getTime();
Calendar cal = Calendar.getInstance();
cal.add(Calendar.DATE, -100);
long start = cal.getTime().getTime();

long s = getPackageTxBytesMobile(uid, cal.getTimeInMillis(), cal1.getTimeInMillis());
long r = getPackageRxBytesMobile(uid, cal.getTimeInMillis(), cal1.getTimeInMillis());

Вот метод:

public long getPackageTxBytesMobile(int uid, long startDate, long endDate) {
    NetworkStats networkStats = null;

    NetworkStatsManager networkStatsManager = (NetworkStatsManager) 
    context1.getSystemService(Context.NETWORK_STATS_SERVICE);
    TelephonyManager tm = (TelephonyManager)context1.getSystemService(Context.TELEPHONY_SERVICE);
    String subId = null;
    if(ActivityCompat.checkSelfPermission(context1, Manifest.permission.READ_PHONE_STATE) ==
            PackageManager.PERMISSION_GRANTED) {
        subId = tm.getSubscriberId();
    }
    Log.d("Startdate: ",""+startDate+"   ");
    Log.d("Enddate: ",""+endDate+"    ");
    try {
        networkStats = networkStatsManager.queryDetailsForUid(
                ConnectivityManager.TYPE_MOBILE,
                subId,
                startDate,
                endDate ,
                uid);
    } catch (Exception e) {
        return -1;
    }
    NetworkStats.Bucket bucket = new NetworkStats.Bucket();
    networkStats.getNextBucket(bucket);
    long tx = bucket.getTxBytes();
    Log.d("tag1","StartTime: "+bucket.getStartTimeStamp());
    Log.d("tag1","EndTime: "+bucket.getEndTimeStamp());

    networkStats.close();
    return tx;
}

и здесь вывод журнала:

2020-04-25 10:08:47.248 17889-17889/com.pkdev.mdmtemp D/tag1: StartTime: 1579168800000
2020-04-25 10:08:47.248 17889-17889/com.pkdev.mdmtemp D/tag1: EndTime: 1579176000000
2020-04-25 10:08:47.280 17889-17889/com.pkdev.mdmtemp D/Startdate:: 1579149527275   
2020-04-25 10:08:47.280 17889-17889/com.pkdev.mdmtemp D/Enddate:: 1587789527275    
2020-04-25 10:08:47.284 17889-17889/com.pkdev.mdmtemp D/tag1: StartTime: 1579154400000
2020-04-25 10:08:47.284 17889-17889/com.pkdev.mdmtemp D/tag1: EndTime: 1579161600000
2020-04-25 10:08:47.324 17889-17889/com.pkdev.mdmtemp D/Startdate:: 1579149527321   
2020-04-25 10:08:47.324 17889-17889/com.pkdev.mdmtemp D/Enddate:: 1587789527320    
2020-04-25 10:08:47.326 17889-17889/com.pkdev.mdmtemp D/tag1: StartTime: 1582466400000
2020-04-25 10:08:47.326 17889-17889/com.pkdev.mdmtemp D/tag1: EndTime: 1582473600000
2020-04-25 10:08:47.360 17889-17889/com.pkdev.mdmtemp D/Startdate:: 1579149527357   
2020-04-25 10:08:47.360 17889-17889/com.pkdev.mdmtemp D/Enddate:: 1587789527357    
2020-04-25 10:08:47.365 17889-17889/com.pkdev.mdmtemp D/tag1: StartTime: 1579161600000
2020-04-25 10:08:47.365 17889-17889/com.pkdev.mdmtemp D/tag1: EndTime: 1579168800000

1 Ответ

1 голос
/ 25 апреля 2020

Вы используете только один NetworkStats.Bucket, используйте hasNextBucket(), чтобы получить также следующие сегменты.

Поэтому измените нижнюю часть вашего метода следующим образом:

long tx = 0L
NetworkStats.Bucket bucket = new NetworkStats.Bucket();
while (networkStats.hasNextBucket()) {
    networkStats.getNextBucket(bucket);
    tx += bucket.getTxBytes();
    Log.d("tag1","StartTime: "+bucket.getStartTimeStamp());
    Log.d("tag1","EndTime: "+bucket.getEndTimeStamp());
}

networkStats.close();
return tx;
Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...