Время загрузки Android с точностью до мксAndroid

Форум для тех, кто программирует под Android
Ответить
Anonymous
 Время загрузки Android с точностью до мкс

Сообщение Anonymous »

Это факт, что и время безотказной работы -s, и Kotlin:

Код: Выделить всё

object X {
private val startTime = Clock.System.now()
private val androidBootTime = startTime - SystemClock.elapsedRealtime().toDuration(DurationUnit.MILLISECONDS)
с X, на который ссылается подкласс Application,
возвращает точность около ±10 секунд, т.е. разные вызовы приводят к разному времени загрузки для одного и того же сеанса загрузки.
Существует ли образец кода Kotlin, обеспечивающий время загрузки с точностью до микросекунды?
Что такое максимально достижимая точность времени загрузки Android?
Фактом также является то, что определить время запуска вашего приложения можно только по статической метке времени, все другие интеллектуальные средства не работают при кэшировании Android. и преднамеренная медлительность
Уникификаторы загрузки Android
Обновление от 29 октября 2024 г.:
есть счетчик загрузки Android 7 + уровень API 24+

Код: Выделить всё

int boot_count = Settings.Global.getInt(getContext().getContentResolver(),
Settings.Global.BOOT_COUNT);
есть uuid загрузочного сеанса:

Код: Выделить всё

cat /proc/sys/kernel/random/boot_id
c4dfb88f-2a9a-49cf-a649-291b4969db88
есть btime, секундная точность эпохи Unix:

Код: Выделить всё

cat /proc/stat | grep btime
btime 1729814103
При плохой загрузке Android с резервной батареей время может быть неправильным
видимо, читается uptime -s

Код: Выделить всё

cat /proc/uptime
408824.96 624814.45
чтобы между двумя показаниями часов можно было получить некоторую точность, например, взять среднее значение, округлить до ближайшей секунды или что-то в этом роде, если разница во времени меньше мс или около того.
Путь вперед — это приемник загрузки и периодическое чтение унификатора, первое расчетное значение времени загрузки, которое считается авторитетным. эмпирические данные для выбора метода
Проблемы с пользовательским интерфейсом
Пользовательский интерфейс Android также может перезапуститься. Я обнаружил две ситуации в logcat:
  • WATCHDOG уничтожает застрявший поток пользовательского интерфейса
  • DeadSystemException
Если в приложении есть фоновая служба с перезапуском, которая никогда не должна завершаться, это может быть обнаружено
может быть полезно передать logcat в потоковую передачу SD-карта емкостью 150 МБ, 1 М строк на каждую. день
Выводы 29 октября 2024 г.
Я буду использовать унификатор загрузки и первое рассчитанное время загрузки
Это все, что может сделать Android.
.
счетчик загрузки работает до сброса 1…
UUID загрузки работает
/proc/uptime так же плохо, как Android SystemClock.elapsedRealtime
/proc/stat не читается без прав root, но btime имеет точность до секунды (в реальном Android с хорошей батареей)
241105 для Android 12 2024 г.:
  • загрузка с неисправной резервной батареей может начаться с неточным временем
    < ли>

    Код: Выделить всё

    uptime -s
    и /proc/stat btime явно плохие
  • после исправления системного времени через NTP из Интернета оба значения меняются
  • поэтому, любая ссылка на время загрузки Android будет иметь погрешность в ±10 секунд из-за особенностей Android, даже если системное время очень точное. Полученное время может быть разным для разных попыток.
  • однако унификаторы загрузки позволяют различать события загрузки.
  • оценку времени загрузки нельзя получать до тех пор, пока системное время, как известно, является точным. Например, убедитесь, что точность времени Android превышает 2 минуты, подключившись к сайту https или обратившись к NTP PTP NITZ GPS.
Определение времени Android через NTP NITZ. Android 12 с 2024 г.:
  • осуществляется только каждые 18 часов.
  • исправляется только в том случае, если отклонение времени превышает 5 секунд.
  • если NTP не может быть прочитан в течение 3 минут, Android ждет еще 18 часов.
  • можно попытаться в рамках ограничений Android, выбрав «Настройки» — «Система» — «Дата и время» — автоматически установить время на «Выкл.». на Вкл.

    если недавний запрос NTP по какой-то причине не удался, он ждет 18 часов или устанавливает время вручную в соответствии с замыслом тупых гуглеров.
[*]невозможно принудительно обновить время, кроме «Настройки» — «Система» — «Дата и время».
  • необходимо подписать Google или системное приложение.
[*]Обратите внимание: если время отключено на 2 минуты и более, сертификаты не будут работать, так как в VPN может произойти сбой. В этом случае проверка подключения Android может завершиться неудачно, и Android вообще не сможет подключиться к Интернету.

Что действительно глупо с точки зрения сотрудников Google, так это ограничение в 5 секунд. В 2024 году должно быть 1 мс. Ничего не стоит
Утверждать, что это дерьмо, тупо и идиотично — ничего не сказать. Это Google пытается сделать Android безопасным без плана

Подробнее здесь: https://stackoverflow.com/questions/791 ... s-accuracy
Ответить

Быстрый ответ

Изменение регистра текста: 
Смайлики
:) :( :oops: :roll: :wink: :muza: :clever: :sorry: :angel: :read: *x)
Ещё смайлики…
   
К этому ответу прикреплено по крайней мере одно вложение.

Если вы не хотите добавлять вложения, оставьте поля пустыми.

Максимально разрешённый размер вложения: 15 МБ.

Вернуться в «Android»