Я пытаюсь понять причину несоответствия данных, которое я замечаю только с парой приложений. И в Tidal, и в Apple Music, если я пропущу треки во время их прослушивания, я сразу получу расхождение в данных от 10% до 15% между суммой использования данных всеми приложениями и общей громкостью для устройства.
Прецедент
Выполняется 36,03 МБ через Tidal (пропуск треков) с включенной функцией Data Saver, чтобы ограничить фоновые данные до минимума.
Счетчики использования данных Android (Настройки - Подключения - Использование данных)
Общий
- Total 36.03MiB
Программы
- Tidal 31 MiB
- Google Play Services 448.04 KiB
- My Data Manager 59.9 KiB
- com.samsung.accessory.wmmanager 10.94 KiB
- Google Play Store 5.27 KiB
- Android.OS 5.13 KiB
- Samsung Push Service 3.59 KiB
-----------------------------------------------
- Total of all Apps 31.52 MiB
Недостающие данные
- Total 4.51 MiB
Мой менеджер данных
Для одного и того же теста данных My Data Manager сообщает те же значения.
- Tidal 30.8 MiB
- etc
NetworkStatsManager
В моем приложении отслеживания я использую NetworkStatsManager.QuerySummaryForDevice для общего объема и строю итоговые данные по приложениям из NetworkStatsManager.QuerySummary, используя uid корзины для идентификатора пакета. Это было подтверждено на нескольких устройствах Oreo.
Из этого я получил:
QuerySummaryForDevice
- Total 37777120 (36.027MiB)
QuerySummary
- Tidal (com.aspiro.tidal) 32511933 (31.005MiB)
- Google Play Services (com.google.uid.shared) 459244 (448.48KiB)
- My Data Manager (com.mobidia.android.mdm) 61333 (59.90KiB)
- com.samsung.accessory.wmmanager 11196 (10.933KiB)
- Google Play Store (com.android.vending) 5397 (5.271KiB)
- Android.OS (com.uid.system) 5246 (5.123KiB)
- Samsung Push Service (com.sec.app.push) 3677 (3.591KiB)
-------------------------------------------------------------------
- Total of all Apps 33058026 (31.527MiB)
Недостающие данные
- Total 4719094 (4.500MiB)
Таким образом, идентичные результаты дают или принимают некоторые крошечные временные расхождения при снятии / просмотре показаний.
В качестве 4-го подтверждения я вытащил файлы / proc / net / xt_qtaguid / iface_stats_all и / proc / net / xt_qtaguid / stats до и после теста, и цифры снова выровнялись в пределах нескольких байтов от вышеуказанных методов.
Цифры количества пакетов также следуют той же схеме с отсутствием ~ 3000 между общим использованием данных и суммой приложений, поэтому я не думаю, что это может быть связано с тем, что заголовки пакетов не отслеживаются в счетчиках приложений.
Итак, мои вопросы:
Ваш первый вопрос, я знаю, почему происходят просчеты.
Rest API работает как запрос-ответ. Вы отправляете запрос, и приходит ответ, и вы манипулируете ответом. Но иногда возникают ошибки типа 404 401 или нет ответа и т. д. Когда это происходит, система может неправильно рассчитать пакеты данных. Иногда системные службы не отслеживаются с помощью диспетчера сети в android.
Какие системные службы конкретно не отслеживаются? Конечно, похоже, что некоторые установленные пакеты используют пакет, который не отображается в статистике, но я хотел бы понять, какова его цель, и должны ли эти данные составлять часть общего количества установленных пакетов.