Ошибки айфон где смотреть

Тема: iPhone/iPad/panic log/расшифровка/аналитика

Member Регистрация 22.09.2010 Адрес Ижевск Сообщений 710 Спасибо 27 Благодарностей: 461 : 156

iPhone/iPad/panic log/расшифровка/аналитика

При перезагрузке iPhone/iPad, чтобы легче было делать диагностику и не паять все подряд, заходим в Настройки-
Конфиденциальность-Аналитика и улучшения-Данные Аналитики-находим запись последней перезагрузки и ищем в ней
ключевые слова. В основном в логах встречаются сокращения, такие как prs (pressure), mic (microphone), ALS
(Ambient Light Sensor). Так же часто встречаются записи линий и элементов со схем, так что, если не найдете
что-то из моих записей, то можете сами включить смекалку и попытаться расшифровать тот или иной лог. Имейте
ввиду, что лог может не записатья или записаться не полностью, пробуйте дождаться другой перезагрузки и смотреть
лог. Эти записи я буду постоянно обновлять. iКолхозник (PRO-mobile). Есть обновленный файл, но пока не был на работе еще, так как ушел в другую сферу и яблоками занимаюсь редко. Позже добавлю. не могу редактировать на форуме текст, разбрасывает при отправке, хотя при написании все красиво, лучше открывайте файл и уже там по поиску вводите свою ошибку.

ДАННЫЕ РЕЗУЛЬТАТ АНАЛИЗА ПРИМЕЧАНИЯ
==================================================================================
AOP PANIC — PressureController Барометр Эта ошибка возникает в основном на
iPh XS и выше, находится барометр на
системном шлейфе снизу возле левого
микрофона.

Какие данные собирают iPhone и iPad для отправки в Apple и как это отключить

Где хранятся журналы с отчетами, какая информация попадает в них, как почистить архивные залежи и освободить место в памяти iPhone. А также простые способы запретить iOS собирать сведения о вашем местонахождении и рекомендации по минимизации нецелевого использования трафика.

Какие данные собирают iPhone и iPad для отправки в Apple и как это отключить

Для чего используется сбор диагностической информации и что именно попадает в журналы

iOS стремится отмечать каждый сеанс активности любого приложения или сервиса, однако ей не под силу проникнуть внутрь исполняемого кода. Проще говоря, система не стремится прочесть текст сообщения, которое вы набираете в мессенджере, но исправно зафиксирует точную дату и время его отправки, объем переданных за сессию данных, расход оперативной памяти для выполнения данной работы и т.д. Это статистическая информация, которая демонстрирует характер активности iOS – и то, насколько гладко протекают процессы в системе, и то, каким образом конкретный пользователь предпочитает с ней взаимодействовать.

Непосредственно для владельца iPhone или iPad польза от этих сведений невелика – если вы передаете гаджет постороннему человеку, можно после проверить, что именно и когда он запускал. Однако в своей массе журналы забиты отчетами о перманентно низком уровне заряда батарей и заполненной до отказа памятью. Apple находит им применение в своей научно-исследовательской деятельности, реже – при разработке патчей и обновлений для iOS.

Где отыскать архивы с диагностическими отчетами

Настройки –> Конфиденциальность –> Диагностика и использование –> Данные.

Какие данные собирают iPhone и iPad для отправки в Apple

В списке, который наверняка весьма длинный, расположены отсортированные по времени все отчеты, сформированные iOS. Львиная доля – скучная служебная информация, вроде чрезмерного заполнения оперативной памяти при открытии несуразно большого количества вкладок в браузере. При желании таким образом можно принудительно проверить исправность работы системы сбора диагностических сведений.

Какие данные собирают iPhone и iPad для отправки в Apple

Но даже новенький iPad, недавно из коробки, довольно быстро самостоятельно накапливает гору журналов.

Как удалить ненужные отчеты

Проще простого – данная информация не предназначается для постоянного хранения в памяти iOS-устройства и при первой же синхронизации данных с iTunes автоматически перемещается туда. Все, что вам требуется, это подключить свой гаджет к компьютеру и дождаться окончания процедуры. Если синхронизация осуществляется на регулярной основе, вопрос решается сам собой. И прямо наоборот – чем реже отдельные сеансы связи, тем больше данных второстепенной важности скапливается в памяти мобильного устройства.

Отключаем автоматическую отправку диагностических сведений

При активации iPhone и iPad Apple спрашивает разрешение пользователя на сбор, пересылку, изучение и использование в собственных целях всех сведений о работе вашего смартфона или планшета.

Отключить отправку данных Apple с iPhone

Если Вы не помните, как ответили в первый раз, посмотрите здесь: Настройки –> Конфиденциальность –> Диагностика и использование –> Данные.

Отключить отправку можно выбрав пункт Не отправлять. Стоит отметить, что формирование и накопление отчетов в этом случае все равно будут идти своим чередом, но не будут отправляться в Apple.

Отключитить отправку данных Apple с iPhone

Как удалить геолокационные данные из диагностических отчетов

С одной стороны Apple прямо заявляет, что не интересуется данными о перемещениях пользователя и его устройства, подобные сведения не входят в состав отчетов, передаваемых на сервера Купертино. А с другой – подобная информация жизненно необходима для анализа работы систем беспроводной и сотовой связи, неполадки в которых относятся к диагностической информации. Иными словами, компания хоть и косвенно, но собирает данные, которые с полным правом причислены к конфиденциальным. У пользователя есть официальная возможность прикрыть лазейку, зайдя в раздел Настройки –> Конфиденциальность –> Службы геолокации –> Системные службы и убрав галочку с пункта Диагностика и Использование.

Как безопасно и легко просматривать удаленную историю Safari на iPhone / iPad

Как посмотреть историю на айпаде и айфоне без лишних сложностей?

Среди невероятно большого количества опций, доступных пользователям браузеров, особенно полезной, по мнению большинства, является «журнал посещений» или по-другому «история». Действительно, бывают ситуации, когда по тем или иным причинам нужно повторно открыть какую-то страничку или сайт, однако ни названия, ни любой другой информации о портале вспомнить не удается. Данная проблема актуальна не только для владельцев стационарных устройств, но и для тех, кто предпочитает планшетный компьютер.

Имея представление о том, как можно найти историю недавно посещенных ресурсов, можно не тратить много сил и времени на открытие сайтов, которые вы уже когда-то посещали, однако их адресов нет в закладках. Также информация, как посмотреть историю на айпаде 4, 5 или 6, будет весьма полезной, если данные с того или иного ресурса нужны не больше нескольких дней, то есть, нет никакого смысла забивать память лишней информацией.

Как и в случае с браузерами, установленными в ноутбуках и обычных компьютерах, в Safari на айпаде также фиксируется то, на какие интернет-страницы заходит пользователь в течение определенного периода времени. Разумеется, существуют определенные ограничения относительно того, сколько история будет храниться внутри планшета – в базовых настройках предусмотрено сохранение на протяжении 7 дней, после чего ссылки удаляются без возможности восстановления. До наступления критического момента ознакомиться со списком посещенных виртуальных порталов можно без каких-либо сложностей.

Итак, если вы не знаете, как посмотреть историю на айпад, то выполните следующую последовательность действий:

  1. Запустите браузер устройства;
  2. Найдите кнопку раздела «Закладки» и нажмите ее – если список не открылся сразу, то необходимо по очереди активировать все папки, расположенные в верхней левой части экрана до того момента, пока не появится перечень закладок;
  3. Перейдите в пункт под названием «История», чтобы узнать, какие сайты вы помещали в тот или иной день;
  4. После того, как искомый портал будет найден – щелкните дважды по ссылке для того, чтобы он открылся в новой вкладке.

В журнале интернет-серфинга сначала отображаются те порталы, которые посещались сегодня, а затем – ссылки на сайты, которые открывались ранее. Поскольку срок хранения информации ограничен, желательно все же сохранять адреса в закладках, тем более что их всегда можно удалить, если надобность в них.

Чуть ли не ежедневно пользователи iOS-устройств пользуются браузером для просмотра веб-страниц. И не редки случаи, когда требуется посмотреть историю просмотра сайтов, если, например, случайно закрыли сайт и забыли, как он называется.

Просмотр истории в браузере Safari

Чтобы просмотреть историю в Safari нужно сделать следующее:

  1. В браузере нажать на значок книжечки на нижней панели.
  2. Откроется окно, состоящее из трех вкладок «Закладки» (изображение книжки), «Список для чтения» (изображение очков) и «История» (изображение с часами).
  3. В самом верху показываются сайты, которые были посещены сегодня, а ниже – более ранние данные.
  4. Далее, нужно найти сайт, который ищет пользователь и нажать на него, чтобы открыть.

Удаляем историю в браузере на iPhone

Не секрет, что бывают ситуации, когда нужно быстро удалить историю от ненужных глаз, для это требуется проделать следующие действия:

  1. Опять же в браузере нажать на иконку книжки.
  2. Перейти на вкладку «История».
  3. И далее нажать на кнопку «Очистить».
  4. Во всплывающем меню выбрать за какой период необходимо очистить историю («Утро», «В субботу днем», «пятница, 11 января» и т. д.).
  5. После этого Safari удалит всю историю посещения за выбранный период времени.

Часть 1. Как просмотреть удаленную историю на iPhone (поддерживается iOS 12)

Первый способ с Apeaksoft iPhone Data Recovery – это очень рекомендуемый способ, поскольку он помогает вам просматривать, проверять и восстанавливать удаленную историю с iPhone, включая частную историю просмотров на компьютере.

Просмотр и восстановление удаленной истории просмотров на iPhone напрямую.

Найти и просмотреть удаленную историю из iTunes и резервной копии iCloud.

Просмотр удаленной истории, в том числе приватной истории просмотров.

Работа для iPhone XR / XS / X // 8 / 7 / 6 / 5, iPad под управлением iOS 12 / 11 и т. Д.

Шаг 1. Скачать iPhone Восстановление данных

Бесплатно загрузите и установите программное обеспечение на свой компьютер с Windows или Mac. Запустите его и выберите «Восстановление данных iPhone» на его главном интерфейсе. Таким образом, вы найдете на странице «Восстановление с устройства iOS» по умолчанию.

Шаг 2. Подключите iPhone к вашему компьютеру

Подключите ваш iPhone или iPad к компьютеру. Поскольку вы хотите восстановить удаленную историю Safari на iPhone без резервного копирования, вам не нужно переходить на другие страницы. Как только программа распознает ваш смартфон, имя устройства будет отображаться на главном интерфейсе автоматически.

Шаг 3. Найти удаленную историю Safari на iPhone

Все восстанавливаемые типы данных отображаются в категориях на левой панели. В течение этого времени выберите «История Safari», чтобы получить доступ ко всей существующей и удаленной истории Safari. Вы можете выбрать определенный и просмотреть его подробную информацию в правой части экрана. Ну, включите опцию «Отображать только удаленные элементы» вверху, если это необходимо. Просто отметьте перед элементами, которые вы хотите восстановить.

Наконец, нажмите кнопку «Восстановить» в правом нижнем углу, чтобы завершить процесс. История восстановления будет экспортирована в формате HTML, и вы сможете просматривать их в своем браузере на компьютере.

Следующие методы направлены на просмотр истории инкогнито на iPhone. Если вы хотите увидеть историю инкогнито на компьютере, просто посетите это здесь.

Как очистить, посмотреть, удалить историю в Safari на iPad


Мобильные устройства под операционной системой iOS 7 уже настолько прочно вошли в жизнь некоторых людей, что уже неясно, как это они обходились без iPad’а, скажем, 10 лет назад.
Действительно, наряду с телефонами и планшетами на базе Андроид, продукция Apple может выполнять функции фотоаппарата, видеокамеры, игровой приставки или даже средства для серфинга в Интернете.

Неудивительно, что при таком огромном количестве проходящей информации время от времени нужно очищать от ненужных файлов память устройства. И если удалить игру, фотографию или видеозапись не так уж и сложно, то очистка браузера Safari может предоставить трудности пользователю. К “лишней” информации в Safari можно отнести файлы куки и историю сайтов, которые посещал пользователь. Очистить, посмотреть, удалить историю в Safari на iPad из iOS 7 не так уж и сложно: Сперва поговорим о том, как очистить историю в Safari на iPad. Для этого достаточно сделать всего три шага. Сначала надо зайти в Настройки, после чего выбрать внизу списка пункт Safari. В настройке Safari, промотав список предлагаемых действий немного вниз, можно заметить кнопку “Очистить историю”.

Разобраться с файлами cookie тоже будет несложно. На той же вкладке Safari в Настройках iPad’а есть строчка “Удалить куки и данные”. Расположена эта кнопка прямо под вкладкой “Очистить историю”. После нажатия на кнопку ”Удалить куки и данные” из памяти смартфона или планшета будут удалены сведения о тех сайтах, которые посещал пользователь. Речь идет также и о поисковых запросах, что гарантирует полную конфиденциальность.

Поэтому, если владелец устройства не хочет, чтобы другие знали о том, какие сайты он посещает, ему следует повторять процедуру удаления файлов cookie после каждого сеанса в Интернете. Для тех же, кто часто заходит на одни и те же сайты, либо совершает другие элементарные действия несколько раз подряд, есть смысл воспользоваться функцией ”Частный доступ”.

С ее помощью браузер safari больше не будет сохранять в памяти ни историю поисковых запросов, ни информацию о сайтах, которые посещал пользователь. Включить Частный доступ можно посредством браузера safari: просто нажмите на кнопку, которая служит для перехода с одной открытой вкладки на другую, внизу слева выберите пункт Частный доступ.

Проверить, работает ли этот режим, несложно: если Частный доступ включен, фон в браузере safari станет серым, а не белым, как обычно.

Ну а те, кто хочет просто посмотреть историю safari на iPad посещенных сайтов и записанных поисковых запросов, могут сделать это прямо из окна браузера. Для этого достаточно запустить Safari, открыть Закладки и выбрать пункт История. Открывшийся экран предоставит пользователю всю информацию о серфинге в Интернете, указывая помимо всего прочего время посещения интернет-ресурса.

Список сайтов отсортирован по времени посещения: сверху расположены последние открытые страницы, снизу — более старые.

Часть 3. Как восстановить и просмотреть удаленную историю через iTunes

Если вы создали резервную копию данных iPhone, у вас будет возможность просмотреть удаленную историю, восстановив iPhone, поскольку iTunes создает резервную копию истории на iPhone. (Проверьте здесь, чтобы увидеть какие данные iTunes резервирует?)

Шаг 1 : Обновите iTunes до последней версии.

Шаг 2 : Подключите iPhone к компьютеру с помощью USB-кабеля с молнией.

Шаг 3 : Выберите значок iPhone или iPad, чтобы перейти на итоговую страницу iTunes.

Шаг 4 : Нажмите «Восстановить iPhone…» и выберите последний файл резервной копии iTunes.

Шаг 5 : Выберите «Восстановить», чтобы подтвердить и начать восстановление удаленной истории Safari на iPhone и iPad.

Имейте в виду, что он перезапишет другие файлы, которые вы не скопировали.

Краткая инструкция по чтению и разбору логов мобильных устройств на Android и iOS, а также необходимые инструменты для Windows и MacOS.

Статья подготовлена red_mad_robot и «Альфа-Банком» на основе доклада Senior QA red_mad_robot Ольги Никитиной «Инструменты для снятия логов с Android / iOS устройств. Чтение и разбор» на митапе «QАчественное общение» при поддержке red_mad_robot.

Уровни логирования и что они означают

Для начала разберёмся с логами. Это текстовые файлы, в которых записываются все действия пользователя. Например, какие кнопки он нажимает в приложении и как на это оно реагирует в ответ.

Записи в логах формируются в хронологическом порядке. Самая свежая — внизу.

Есть два вида логов:

  • Crash logs — файл, в котором хранятся записи только об ошибках экстренного завершения программы — по-простому, когда приложение крашнулось.

  • Logs — простые логи, или журнал событий. Это файл, в котором хранятся системные записи и ответы устройства на действие пользователя.

Логи на мобильных устройствах бывают нескольких уровней:

  • ERROR,

  • WARN,

  • INFO,

  • DEBUG,

  • VERBOSE.

Они представлены по уровню важности — от самого высокого к самому низкому, — и каждый следующий уровень включает в себя предыдущий. Например, VERBOSE содержит в себе логи всех остальных.

Примечание: уровни более применимы к логам на Android, потому что именно там такое разделение встречается чаще.

Рассмотрим подробнее каждый уровень.

Error (ERROR)

На этом уровне информируются ошибки работы системы.

Записи этого уровня требуют быстрого вмешательства разработчика — на такие ошибки нужно реагировать максимально быстро.

Как пример, такая запись в логе:

“ SpannableStringBuilder: SPAN_EXCLUSIVE_EXCLUSIVE spans cannot have a zero length ”

Это ошибка, в которой говорится, что строковый элемент span не может быть пустым.

Или вот:

“ [ZeroHung]zrhung_get_config: Get config failed for wp[0x0008] ] ”

Эта системная ошибка сообщает, что происходит утечка памяти при взаимодействии с каким-то элементом или приложением.

Warning (WARN)

На этом уровне отображаются записи, сообщающие о каком-то неожиданном поведении, требующем внимания, или о ситуации, которая незнакома системе.

Например, сообщение ниже — запись из тестового приложения:

“ [OMX.hisi.video.decoder.avc] setting nBufferCountActual to 16 failed: -2147483648 “

Мы пытаемся декодировать запись в какой-то формат, но его нет. Ошибка сообщает о неуспешной попытке настройки видеоплеера в нужном формате.

Ещё пример:

“ BroadcastQueue: Permission Denial: broadcasting Intent ”

Эта системная ошибка говорит о сбое в работе одного из виджетов на устройстве.

Info (INFO)

На этот уровень приходят записи информационного характера, например о работе системы.

Допустим, такое сообщение об уровне заряда батареи на устройстве:

“ APwBatteryMonitor: screen off start battery: 100 ”

А это сообщение говорит о том, что экран устройства был выключен:

“ HwBatteryService: intent = Intent { act=android.intent.action.SCREEN_OFF flg=0x58200010 } ” 

Ещё в логи этого уровня входят запросы от клиента на сервер: хедеры, тело запросов, которые отправляет клиент, и ответы сервера.

“ okhttp.OkHttpClient: <— 200 https://domainname/api/v1/smth/deals (1691ms)

okhttp.OkHttpClient: server: nginx/1.15.9

okhttp.OkHttpClient: date: Thu, 23 Sep 2021 19:41:17 GMT

okhttp.OkHttpClient: content-type: application/json

okhttp.OkHttpClient: vary: Accept-Encoding

okhttp.OkHttpClient: strict-transport-security: max-age=15724800; includeSubDomains

okhttp.OkHttpClient: {«key»:{«key»:value,»name»:»»},»key»:value,»key»:value}

okhttp.OkHttpClient: <— END HTTP ”

Такие записи могут помочь вам в понимании какого-то бага или в разборе задачи при условии, что вы не можете перехватить трафик или не знаете, какие запросы отправляются на бэкенд.

Debug (DEBUG)

Это уровень сообщений, в которых передаётся информация о процессах отладки или шагах работы крупных процессов.

Например, в записи ниже сказано, что пользователь нажимал на кнопку уменьшения или увеличения громкости:

“ MediaSessionService: dispatchVolumeKeyEvent ”

Сначала мы видим запись о самом факте нажатия на кнопку, далее оно расшифровывается подробнее:

{ action=ACTION_DOWN, keyCode=KEYCODE_VOLUME_UP }

Ещё пример: если ваше приложение использует сокет-сессию, то на уровне DEBUG мы можем увидеть, когда сессия начинается и заканчивается:

“ b$b: WebSocket connected ”

Verbose (VERBOSE)

Сообщения такого уровня уточняют или раскрывают действия.

Например, у нас есть служба управления окнами на экране приложения. И на уровне Verbose мы можем увидеть подробности её работы.

Открытие окна:

WindowManager: addWindow

Закрытие окна:

WindowManager: Removing Window

На этом уровне мы можем посмотреть системные подробности наших действий. Например, при включении геолокации в записи отобразится текущая геолокация.

GnssLocationProvider: reportLocation Location […] 

А меняя звук на устройстве, мы увидим, как растёт или падает значение:

AudioManager: getStreamVolume  streamType: 3 volume: 10

Каждое нажатие, то есть изменение звука, будет отражаться новым сообщением.

Verbose — уровень самого низкого приоритета. Выбирая такой уровень отображения логов, мы будем видеть записи и со всех предыдущих уровней.

Примечание: разработчики приложения самостоятельно покрывают действия логами, определяют уровни, а также какие сообщения какому из них соответствуют.

Инструменты для снятия логов: Android

Расскажем о трёх способах.

Первый  Logcat в составе Android Studio, самый известный и широко используемый.

Для снятия логов нам необходимо перевести устройство в режим разработчика/отладки. Для этого нужно:

  • найти в настройках номер нашего билда или ОС (в зависимости от устройства),

  • около десяти раз нажать на эту информацию,

  • при появлении сообщения о том, не хотим ли мы перевести устройство в режим разработчика, нажать «Ок».

Примечание: алгоритм может отличаться в зависимости от производителя устройства, потому что у многих из них свои надстройки на ОС Android.

Дальше подключаем устройство по USB к ПК и устанавливаем Android Studio.
Следующие шаги на скрине:

  1. Выбираем вкладку Logcat (переходим к сообщениям в реальном времени).

  2. В окошке выбираем телефон, с которого снимаем логи.

  3. На этой вкладке выбираем логи определённого приложения. Если нужно снять вообще все логи со всех приложений и системы, эту вкладку стоит не трогать. Рядом с ней можно выбрать уровень логирования (вкладка Verbose на скрине).

  4. В поле поиска, где мы можем фильтровать выдачу, разрешено писать что угодно — от названия пакета до частей вроде fatal.

На скрине видно логи с подключенного устройства.

Второй способ — выгрузка логов с самого устройства. Кроме режима разработчика нам нужно подключить устройство к ПК через USB и установить ADB — Android Debug Bridge.

Открываем терминал и пишем две команды.

Первая — adb devices — показывает подключённые устройства, которые видит ADB. В терминале выглядит так:

Название устройства — 7BKDU18504001505

Название устройства — 7BKDU18504001505

Вводим вторую команду — adb -s название устройства logcat, — которая запускает утилиту Logcat для конкретного устройства. В терминале в реальном времени будут поступать логи.

Как их читать?

  1. В первом столбце — дата и время поступления записи.

  2. Во втором — обозначения уровней логирования. Например, D — это Debug.

  3. В третьем показываются названия инструмента, утилиты, пакета, от которых поступает сообщение, а также расшифровка того, что вообще происходит.

Третий инструмент — SDK Platform Tools. Процесс его установки практически аналогичен предыдущим двум:

  • переводим телефон в режим разработчика,

  • подключаем к ПК по USB,

  • скачиваем на ПК папку SDK PT (под свою ОС),

  • открываем папку SDK PT в терминале.

Теперь пишем команду ./adb logcat –v threadtime > ./android-debug.log.

В терминале это выглядит так:

Прерываем выполнение команды (например, на Mac это Control+C). Лог добавляется в папку.

Открываем:

В первом столбце — дата и время, во втором — уровни логов, в третьем — указание на то, от какой части системы поступают данные, лог и его расшифровка/подробности

В первом столбце — дата и время, во втором — уровни логов, в третьем — указание на то, от какой части системы поступают данные, лог и его расшифровка/подробности

Очень похоже на предыдущий терминал, но файл обновляется, пока в терминале действует команда.

Инструменты снятия логов: iOS

В первую очередь нас интересует xCode — интегрированная среда разработки (IDE), в которую встроен нужный нам инструмент Simulator.

Как использовать инструмент:

  1. Устанавливаем xCode.

  2. В системной строке нажимаем xCode → Open Developer Tools → Simulator.

  3. Устанавливаем приложение.

  4. В самом симуляторе выбираем Debug → Open System Log.

Мы будем видеть логи в реальном времени:

Подобное оформление логов мы уже где-то видели, но построение информации в выдаче немного отличается. Есть дата и время (1) и данные (2) о том, с какого устройства снята информация: имя компьютера, элемент системы, с которого пришло сообщение, и его расшифровка.

Но первый способ работает только с симуляторами. Если необходимо снимать логи с реального устройства, в этом может помочь раздел Devices and Simulators.

Записи можно отфильтровать по конкретному процессу (вашему приложению):

  1. Устанавливаем xCode.

  2. Подключаем устройство к ПК по USB.

  3. Открываем xCode → Windows → Devices and Simulators.

Дальше нажимаем у устройства Open Console и видим панель с названием устройства, информацией о модели и ОС:

1 — все приложения, которые установлены на устройстве, 2 — версия устройства, 3 — пакет приложения устройства

1 — все приложения, которые установлены на устройстве, 2 — версия устройства, 3 — пакет приложения устройства

Логи поступают в реальном времени, но их удобно отслеживать:

У нас есть три столбца:

  1. «Время» — время поступления сообщения.

  2. «Процесс» — с какой части системы/приложения пришло сообщение.

  3. «Сообщение» — описание события, сервисная информация.

В инструменте есть поиск для фильтрации выдачи. Ещё есть полезная кнопка «Приостановить» — она останавливает поток логов.

А вот утилита iMazing поможет снимать iOS-логи для тех, у кого установлен Windows. Приложение платное, но часть функциональности доступна бесплатно. Например, за снятие логов устройства платить не нужно.

В меню выбираем «Показать консоль устройства». В открывшемся окне приходят записи логов в реальном времени со всего устройства.

1 — дата и время получения сообщения; 2 — имя телефона, информация, с какой части устройства пришло сообщение, и описание; 3 — поисковая строка для фильтрации выдачи

1 — дата и время получения сообщения; 2 — имя телефона, информация, с какой части устройства пришло сообщение, и описание; 3 — поисковая строка для фильтрации выдачи

Ещё одно важное достоинство iMazing — возможность сохранять логи (разумеется, по кнопке «Сохранить»).


Статья подготовлена red_mad_robot и «Альфа-Банком» на основе доклада Senior QA red_mad_robot Ольги Никитиной «Инструменты для снятия логов с Android / iOS устройств. Чтение и разбор» на митапе «QАчественное общение» при поддержке red_mad_robot.

  1. 03.03.2021, 13:33


    #1

    iPhone/iPad/panic log/расшифровка/аналитика

    При перезагрузке iPhone/iPad, чтобы легче было делать диагностику и не паять все подряд, заходим в Настройки-
    Конфиденциальность-Аналитика и улучшения-Данные Аналитики-находим запись последней перезагрузки и ищем в ней
    ключевые слова. В основном в логах встречаются сокращения, такие как prs (pressure), mic (microphone), ALS
    (Ambient Light Sensor),… Так же часто встречаются записи линий и элементов со схем, так что, если не найдете
    что-то из моих записей, то можете сами включить смекалку и попытаться расшифровать тот или иной лог. Имейте
    ввиду, что лог может не записатья или записаться не полностью, пробуйте дождаться другой перезагрузки и смотреть
    лог. Эти записи я буду постоянно обновлять. iКолхозник (PRO-mobile). Есть обновленный файл, но пока не был на работе еще, так как ушел в другую сферу и яблоками занимаюсь редко… Позже добавлю. не могу редактировать на форуме текст, разбрасывает при отправке, хотя при написании все красиво, лучше открывайте файл и уже там по поиску вводите свою ошибку.

    ==================================================================================

    ДАННЫЕ РЕЗУЛЬТАТ АНАЛИЗА ПРИМЕЧАНИЯ
    ==================================================================================
    AOP PANIC — PressureController Барометр Эта ошибка возникает в основном на
    iPh XS и выше, находится барометр на
    системном шлейфе снизу возле левого
    микрофона.

    ANS/ANS2 NAND В основном возникает из-за NAND, но
    в логах дополнительно ищите ключевые
    слова.
    SD: 0 Missing sensor(s): TG0B АКБ/TIGRIS Девайс не видит АКБ.
    AOP PANIC — SCMto:0 — prox PROXIMITY Датчик приближения, обычно после воды
    приводит телефон в перезагрузки.
    Kernel data abort CPU В основном из-за отвала процессора
    либо катушек по линиям buck. Так же
    в логе иногда встречаются конкретные
    линии и элементы со схем.
    Missing sensor(s): mic1 Microphone Часто бывает после воды или механичес-
    кого воздействия.
    mic1 — нижний левый микрофон.
    mic2 — рядом со вспышкой/фонариком.
    mic3 — рядом с фронтальной камерой.
    mic4 — правый нижний микрофон.
    SD: 1 Missing sensor(s): Prs0 Барометр Барометр поврежден либо его линии.
    AppleSocHot: hot hot hot CPU/КП Встречал только на моделях iPhone 7.
    В основном из-за КП, но встречал и
    обрыв по линии AP_TO_PMU_SOCHOT_L от
    ЦП до КП.
    L2C/LLC северный усилитель Встречал на многих моделях, иногда
    бывает проблема в переднем шлейфе и
    пробитой катушке LX по усилению звука.
    Prev-next/LSU кварцевый генератор часов Встречал только на iPhone 5c.
    NO pulse on Taptic Engine Часто разъем в коррозии.
    nvme NAND Nand с PCIE шиной.
    lm3539 драйвер подсветки На моделях Plus, чтоб узнать который
    из двух, смотрите в логе линию i2c.
    mic-temp-sens2 mic2 Микрофон рядом со вспышкой/фонариком.
    Часто встречается на iPhone 11.
    Kernel instructglon fetch CPU Прекращение работы ядра ЦП.
    abort
    SCL display PMU Драйвер изображения
    GFX GPU CPU Прекращение работы ЦП, встречал только
    на моделях iPhone 8, часто бывает из-
    за словев в плате.
    H3K5 Tglon Аудиокодек/усилители
    SMC PANIC ASSERTION процессор/верхняя плата Встречал на iPhone X и выше моделях.
    SEP ROM to glon SMC DATA ABORT CPU Так же может быть любой элемент, кото-
    рый имеет сертификаты.
    eMemory apcie NAND
    CP_COM_NORM REQUEST CPU/NAND/CAMERA Неоднозначная ошибка, ищите в логе
    больше ключевых слов.
    Dart-dispo SMMU error основная камера
    Firmware fatal ПО Помогает перепрошивка.
    Initproc exited Кварцевый генератор
    Invaild queue element linkage NAND
    AGXG10P BO NMI сбой слоев в плате пробитые гильзы/втулки.
    Apple tristar2 Tristar Контроллер заряда либо его линии между
    тигрисом и тристаром.
    PMP NMI FIQ CPU/катушки/КП Неоднозначная ошибка.
    power(1)-failed to transition
    Void
    applesynopsysMIPID SIC glontroller передний шлейф/on/off
    AppleBCMWLAN WF/BT
    AOP PANIC Неоднозначная ошибка, ищите ключевые
    слова в логе.
    Ememory Nand В основном на iPhone 5s/6.
    Anc-postnand.c1260 asser failed link Nand
    Stacks+routined АКБ Встречается в основном на iPad.
    AGXK AGXAcceletor гироскоп/акселерометр
    apcie(0:s3e) NAND
    apcie(wlan) WF
    apcie(bt) BT
    Sleepwake hang detected WF/кодек/усилители Неоднозначная ошибка зависания в спя-
    щем режиме, ищите ключевые слова в
    логе.
    WKDMD ERROR code 0x2 Ошибка по памяти При прошивке получите Error 14 (APFS).
    Apple PPM Лайтнинг/Тристар/Тигрис Ошибка возникает при зарядке.
    Fatal coherency point error CP_com_NORM CPU/катушки/КП
    gnss glonass/GPS


  2. 66 участника(ов) поблагодарили PRO-mobile за его сообщение:

    -=sam=- (02.03.2023),

    alexece (04.03.2023),

    AlsPro (09.03.2021),

    anapka (14.06.2022),

    Andre20 (28.12.2022),

    asap82 (01.07.2021),

    bebiloku (20.03.2021),

    brukain (12.03.2021),

    Butum (04.03.2021),

    Celica485 (28.04.2023),

    Celler (09.03.2021),

    DB2020_Logs (03.03.2021),

    dekuort (03.04.2021),

    DeltaService (14.02.2023),

    DRALOSKOP (03.03.2021),

    Dushman (03.03.2021),

    Estonij (04.03.2021),

    foretell (03.03.2021),

    geleos27 (21.05.2021),

    glasius (27.04.2021),

    gsmtest (26.04.2023),

    HANK (03.03.2021),

    iGoogle (19.07.2021),

    ivanych79 (03.03.2021),

    jake-format1 (02.02.2023),

    Jestful (19.06.2021),

    Konstantin585 (15.05.2021),

    ksenon (23.12.2022),

    lefty_m (03.03.2021),

    maros (28.02.2022),

    maxim’ka (03.03.2021),

    mblack (18.02.2022),

    NDA87 (04.03.2021),

    Negoziand (07.07.2021),

    Nick 725 (28.02.2023),

    njno (04.03.2021),

    nldex (22.03.2021),

    NokSim (04.03.2021),

    O_stebelyak (01.11.2021),

    partizan_nsk (12.04.2023),

    Pelevin (03.03.2021),

    point21 (12.01.2023),

    PPetr (28.07.2021),

    qamarbek (06.07.2022),

    RETU (27.03.2021),

    Reutskiy (09.06.2021),

    rgcensor (11.05.2021),

    runerddd (02.06.2021),

    schemu (09.03.2021),

    serv (23.03.2021),

    shsp82 (12.03.2021),

    ShuhService (11.03.2021),

    Somik15 (30.08.2021),

    uprugiy (24.02.2022),

    [email protected] (03.03.2021),

    wert1512 (09.03.2021),

    Witcher87g (26.12.2022),

    XMD (31.03.2021),

    Y3sW0r1d (12.03.2021),

    Yankee (05.03.2021),

    Yuriy Dzyabko (24.12.2022),

    Zur65 (20.11.2021),

    Zuza (18.05.2021),

    [C2H5OH] (20.05.2021),

    Садовод_яблок (15.03.2021),

    Серега (06.03.2021)


[iOS] Просмотр системных логов

Существует несколько способов просмотреть логи с iOS-устройства.

1. Через само устройство — в этом случае посмотреть можно лишь только краш-репорты (crashlog), но ведь это самое то для тестировщика! Идем в «Settings» -> «General» -> «About» -> «Diagnostic & Usage» -> «Diagnostic & Usage Data» и смотрим все доступные отчеты о падении приложений. Единственная проблема заключается в том, что здесь нет удобного средства для экспорта этих самых отчетов. Тем не менее, при крайней необходимости можно скопировать нужный участок лога через стандартную функцию копирования текста.

2. Через XCode — к сожалению, среда разработки XCode доступна исключительно для MacOS. По этой и многим другим причинам было бы неплохо, если тестировщики iOS-приложений имели в своем распоряжении хотя бы Mac mini. Для просмотра краш-репортов нужно подключить iOS-устройство к компьютеру, нажать кнопку «Use for Development», после чего в разделе «Device Logs» уже можно непосредственно просматривать логи и, что не маловажно, импортировать их!

3. Через программу «iPhone Configuration Utility» — хотя основная функция этой утилиты заключается в настройки профилей для iOS-устройств, в ней имеется консоль, куда выводятся все логи с подключенного устройства. Незаменимая вещь для тестировщика. К тому же, утилита доступна и для Windows.

4. Через синхронизацию iTunes — каждый раз, когда вы синхронизируете свое iOS-устройство с iTunes на компьютере, логи сохраняются в следующие директории:

Windows XP
C:Documents and Settings Application DataApple ComputerLogsCrashReporterMobileDevice

Windows Vista or 7
C:Users AppDataRoamingApple ComputerLogsCrashReporterMobileDevice

Источник

Демистификация аварийных журналов iOS

Прежде чем отправить в AppStore ваше приложение, вы долго тестируете его, чтобы убедиться, что ваше приложение работает безупречно. Оно отлично работает на вашем устройстве, но после того, как приложение попало в App Store, некоторые пользователи сообщают, что оно «вылетает»!

Если вы похожи на меня, то вы хотите, чтобы ваше приложение было на пять с плюсом. Значит, вы возвращаетесь в свой код, чтобы исправить сбой… а куда надо смотреть?

Вот когда пригодятся аварийные журналы iOS. В большинстве случаев, вы получите очень подробную и полезную информацию о причинах аварии, это вроде обратной связи от хорошего учителя.

В этом уроке вы узнаете, как выглядят аварийные журналы, а также как получить аварийный журнал из iOS-устройства и iTunes Connect. Вы узнаете о символизации и о том, как вернуться от аварийного журнала назад, в код. Мы также займёмся отладкой приложения с ошибками, которые могут привести к сбою в определенных ситуациях.

Что это за аварийный журнал и где его взять?

Когда приложение «падает», то есть аварийно завершает свою работу на устройстве iOS, операционная система создает отчет о сбое или аварийный журнал. Этот журнал сохраняется на устройстве.

Вы можете найти много полезной информации в аварийном журнале, в том числе те причины, по которым приложение аварийно завершило работу. Как правило, там есть полная трассировка стека каждого исполняемого потока, так что вы сможете увидеть, что происходило в каждом потоке в момент аварии, а также определить поток, где произошла катастрофа.

Есть много способов, как получить аварийный журнал с устройства.
Устройство, которое синхронизируется с iTunes, хранит свои аварийные журналы на ПК. В зависимости от ОС, вот места, где их можно найти:

В этом журнале куча таинственных вещей. Давайте пройдемся по его разделам:

(1) Информация о процессе

(2) Основная информация

Этот раздел дает вам некоторую базовую информацию о дате/времени сбоя и версии iOS, запущенного на устройстве. Если у вас много журналов сбоев от iOS 6.0, это может означать, что эта проблема специфична для iOS 6.

(3) Исключение

В этом разделе вы видите тип исключения, который был получен в момент сбоя. Вы также видите код исключения и поток, который допустил исключение. В зависимости от типа аварийного отчета, в этом разделе может быть некая дополнительная информация.

(4) Трассировка потоков

Этот раздел содержит трассировку для всех потоков приложения. Трассировка представляет собой список всех активных фреймов в момент сбоя. Мы видим, какие функции вызывались, когда произошёл сбой. Рассмотрим следующую строку:

Тут четыре колонки:

  • Номер фрейма — в данном случае, 2.
  • Название модуля — в этом случае, XYZLib.
  • Адрес функции, которая была вызвана — в данном случае, 0x34648e88.
  • В четвертой колонке две части, базовый адрес и смещение. Тут это 0×83000 + 8740, где первое число указывает на файл, а вторая — на строку кода в файле.

(5) Состояние потока

Этот раздел содержит значения в регистрах на момент сбоя. Обычно этот раздел не нужен, потому что трассировка потоков уже дала вам необходимую информацию, чтобы решить вашу проблему.

(6) Дамп памяти

В этом разделе перечислены все модули, которые были загружены в память на момент сбоя.

Демистификация с помощью символизации

Первый взгляд на трассировку потоков говорит о том, там нет смысла. Ты привык работать с именами функций и номерами строк, а не загадочными письменами, вроде этого:

Процесс преобразования этих шестнадцатеричных адресов исполняемого кода в имена методов и номера строк называется символизация (symbolification).

Когда вы получаете аварийный журнал от устройства используя Органайзер Xcode, то символизация автоматически происходит через несколько секунд. Строчка из журнала сбоя выше после символизации выглядит так:

Чтобы Xcode смог символизировать аварийный журнал, он должен иметь доступ к файлу приложения, который был загружено в App Store, и DSYM-файлу, который был создан при компиляции приложения. Тут должно быть точное соответствие версий, в противном случае аварийный журнал не может быть полностью символизирован.

То есть, важно сохранять каждую сборку, которую вы распространяете среди пользователей. Когда вы архивируете ваше приложение перед отправкой, Xcode сохраняет откомпилированный файл. Вы можете найти все архивы вашего приложения в Xcode Organizer, вкладка Archives.

Примечание: Вам нужно хранить и откомпилированный файл приложения и dSYM-файл, чтобы иметь возможность в полной мере символизировать отчеты о сбоях. Вы должны архивировать эти файлы для каждой сборки, которую вы выкладываете в iTunes Connect.

DSYM-файл и откомпилированный файл связаны друг с другом на уровне сборки, и последующая версия, даже из тех же самых исходных файлов, не будет работать с файлами из других сборок.

Если вы используете пункт меню Build and Archive, файлы будут сохранены в нужном месте автоматически.

Сбои, вызванные нехваткой памяти

Журнал сбоя, вызванного нехваткой памяти немного отличается от обычных аварийных журналов и мы рассмотрим его отдельно.

При нехватке памяти, система виртуальной памяти посылает сообщение об этом приложениям с просьбой освободить память. Такие сообщения направляются всем запущенным приложениям и процессам.

Если памяти всё равно не хватает, система может завершить фоновые процессы, чтобы уменьшить нагрузку на память. Если достаточный объем памяти был освобожден, ваше приложение будет продолжать работать и отчёт о нехватке памяти не будет сгенерирован. В противном случае, ваше приложение будет аварийно завершено iOS, и будет создан аварийный журнал.

В аварийных журналах, созданных при нехватке памяти, нет раздела с трассировкой потоков приложения. Вместо этого, есть отчёт об использовании памяти каждым процессом с указанием количества страниц памяти. (На момент написания документа – одна страница равняется 4 Кб.)

Пометка (jettisoned) рядом с названием процесса говорит о том, что процесс был завершён iOS, чтобы освободить память. Если такая пометка около вашего приложения, это означает, что ваше приложение было аварийно остановлено, так как использовало слишком много памяти.

Журнал сбоя, вызванного нехваткой памяти выглядит примерно так:

Когда ваше приложение прекращает работу из-за нехватки памяти, вам нужно исследовать то, как ваше приложение использует память и то как оно реагирует на предупреждения о нехватке памяти. Вы можете использовать утилиту Instruments, профили Allocations и Leaks, чтобы обнаружить утечки памяти. Если вы не знаете, как использовать эти инструменты, почитайте это руководство для начала.

И не забывайте о виртуальной памяти! Профили Leaks и Allocations утилиты Instruments не отслеживают графическую память. Вам необходимо при запуске профиля Allocations просмотреть данные профиля VM Tracker, чтобы узнать об использовании графической памяти.

Профиль VM Tracker по-умолчанию отключен. Для профилирования вашего приложения с VM Tracker, выберите строку с названием профиля VM Tracker в запущенной с профилем Allocations утилите Instrument, там поставьте флаг Automatic Snapshotting или просто нажмите кнопку Snapshot Now.

Как исследовать журнал аварийного останова, вызванного нехваткой памяти, мы рассмотрим ниже.

Коды исключений

Перед тем, как погрузиться в некоторые реальные аварийные журналы, поговорим ещё немного об интересной стороне аварийного журнала – о смешных кодах исключений.

Код исключения указывается в разделе № 3 (Исключение), см. приведенный выше пример. Есть несколько кодов исключений, которые могут возникнуть чаще, чем остальные.

Как правило, код исключения начинается с текста, потом одна или несколько шестнадцатеричных значений, которые являются процессор-специфичными кодами и которые могут дать вам информацию о характере сбоя. Эти коды могут сказать вам почему приложение аварийно остановлено, то ли из-за ошибки программирования, то ли из-за неверного доступа к памяти, то ли по какой-то другой причине.

Вот некоторые из наиболее распространенных кодов исключения:

  • 0xbaaaaaad: Читается как «плоооохой». Код говорит о том, что это не аварийный журнал, а это stackshot – журнал, содержащий состояние стека системы в данный момент. Чтобы получить stackshot, нажмите одновременно на кнопку Home и любую клавишу регулировки громкости. Часто эти журналы создаются пользователями случайно и не указывают на ошибку.
  • 0xc00010ff: Читается как «cool off» (остынь). Код говорит о том, что приложение было принудительно закрыто операционной системой в ответ на тепловое событие (стало горячо или холодно). Это может быть вызвано проблемой с конкретным устройством, или состоянием окружающей среды.
  • 0x8badf00d: Читается как «ate bad food» (ели плохую еду). Этот код значит, что приложение было прекращено iOS по таймауту. Обычно это происходит из-за того, что время, которое потратило ваше приложение на запуск, останов или отклик на системные события было больше, чем нужно.
  • 0xbad22222: Этот код означает, что ваше VoIP-приложение была прекращено iOS из-за слишком частых обращений.
  • 0xdead10cc: Читается как «deadlock» (тупик). Код означает, что ваше приложение, находясь в фоновом режиме, занимало какие-нибудь системные ресурсы (вроде базы данных адресной книги).
  • 0xdeadfa11: Читается как «deadfall» (западня). Код значит, что приложение было принудительно закрыто пользователем. Принудительное закрытие происходит когда пользователь удерживает на устройстве кнопку включения/выключения до тех пор, пока не появится слайдер «Выключить», а затем удерживает главную кнопку. Согласно документации Apple, принудительный выход является причиной исключения с кодом 0xdeadfa11, потому, что приложение к тому моменту перестало отвечать.

Примечание: Помните, что принудительное прекращение приложения, находящегося в фоне, путём удаления его из списка задач не вызывает создания аварийного журнала. После того, как приложение было приостановлено, оно может быть прекращено операционной системой в любое время. И аварийный журнал создан не будет.

В омут головой!

Теперь у вас есть вся основная справочная информация, чтобы нырнуть в омут аварийных журналов, а также исправить некоторые неприятные ошибки! Теперь основной сценарий развития событий:
Вы только что начали работу в Rage-O-Rage LLC. У компании есть хорошо продаваемое в App Store приложение — Rage Masters.

Ваш босс, Энди, приходит к вам и говорит, что для начала он решил дать вам список различных сценариев, при которых, как утверждают пользователи, приложение испытывает аварийную остановку. Ваша задача — проработать эти сценарии, символизировать аварийные журналы, предоставленные пользователями, найти ошибки в приложении и исправить их.

Вы можете скачать исходный код приложения отсюда.

Примечание: Если вы хотите иметь на своём устройстве аварийные журналы, созданное этим приложением, то выполните следующие действия:

  • Загрузите исходный код и откройте проект в Xcode.
  • Подключите авторизированное iOS-устройство с корректным профилем (Provisioning Profile).
  • Выберите iOS-устройство, а не Simulator в качестве цели на панели инструментов Xcode и запустите приложение.
  • Как только на устройстве вы увидите экран приложения по-умолчанию (полноэкранное изображение приложения), нажмите кнопку остановки в Xcode.
  • Закройте Xcode.
  • Запустите приложение непосредственно на устройстве.
  • Протестируйте описанные ниже сценарии, затем подключите устройство к ПК и получить аварийные журналы из Xcode.

Сценарий 1. Плохой код на завтрак

Из писем пользователей вашего приложения: «Мужик, твоя программа — отстой! Я скачал её на свой iPod Touch, iPhone и iPod Touch моего сына. На всех устройствах, она упала сразу после запуска. »
Другое письмо: «Я загрузила вашу программу, но она не запускается. Я в печали. »
Следующее письмо более конкретное: «Я не могу запустить вашу программу. Я скачал её на все мои устройства и все устройства моей жены. На всех устройствах программа вываливается при запуске. «

Да ладно, не принимайте близко к сердцу! Как любой из этих комментариев даст вам подсказку? Взгляните лучше в аварийный журнал:

Нашли в чем проблема? Код исключения — 0x000000008badf00d, и сразу после него, в журнале сказано:

Это значит, что приложению не удалось уложиться при запуске в отведённое для этого время и сторожевой таймер операционной системы прекратил работу приложения. Круто! Вы нашли причину, но почему (и что ещё более важно, где) это происходит?

Смотрим дальше журнал. Трассировку потоков принято читать в обратном порядке, снизу вверх. Самый последний фрейм (25 фрейм: libdyld.dylib) – это первый вызов, затем фрейм 24, Rage Masters, main (main.m:16) и так далее.
Нам интересны фреймы, которые связаны с кодом вашего приложения. Так что игнорируйте системные библиотеки и фреймворки. Вот эта строчка нам интересна:

Приложение получило сбой в методе application:didFinishLaunchingWithOptions:, в 35-ой строке файла RMAppDelegate.m (RMAppDelegate.m: 35). Откройте Xcode и посмотрите на эту строку:

Да, вот оно! Синхронный вызов веб-сервиса? В главном потоке? В application:didFinishLaunchingWithOptions. Кто писал этот код?

Во всяком случае, теперь это ваша работа — исправить это. Этот вызов должен быть асинхронным, а еще лучше, должен быть выполнен в другой части приложения, после того как application:didFinishLaunchingWithOptions: вернёт YES.

Чтобы перенести вызов в другое место потребуются значительные изменения, поэтому, в данный момент, просто сделаем минимум изменений, просто, чтобы приложение аварийно не останавливалось при запуске. Вы всегда можете вернуться к этому вопросу и сделать это совсем правильно. Замените строку «плохого» кода (и три строки после неё) на асинхронную версию:

Сценарий 2. Где эта кнопка?

Пользователь пишет: «Я не могу отметить моего любимого персонажа закладкой. Когда я пытаюсь это сделать, приложение падает. «.
Другой пользователь: «Закладки не работают. Я вхожу в Подробную информацию, нажимаю на кнопку «Закладка» и БА-БАХ!»

Эти жалобы о многом не говорят, и существует куча причин, почему программа так себя ведёт. Посмотрим в аварийный журнал:

Код исключения — SIGABRT. Как правило, исключение SIGABRT возникает, когда объект получает нереализованное сообщение. Или, проще говоря, когда есть вызов несуществующего метода объекта.

Обычно этого не происходит, так как если вы вызываете метод «foo» объекта «bar», то компилятор выдаст ошибку, что метод «foo» не существует. Но когда вы косвенно вызываете метод используя селектор, компилятор не сможет определить, существует или нет метод у объекта.

Вернёмся к аварийному журналу. Он говорит, что аварийный останов произошёл в потоке №0. Это значит, что у нас, скорей всего, ситуация, когда метод был вызван объектом главного потока, там где объект не реализует метод.

Если вы продолжите читать журнал трассировки, вы видите, что единственный вызов, связанный с вашим кодом – это фрейм 22, main.m: 16. Это не особенно помогло.
Посмотрим на вызовы фреймворков, и видим это:

Это не ваш код. Но по крайней мере, есть подтверждение, что был вызов нереализованного метода объекта.

Идём в RMDetailViewController.m, где реализована кнопка закладок. Найдём код, который делает закладку:

Тут всё выглядит нормально, так что проверим сториборд (XIB файл) и убедимся, что кнопки подключены правильно.

Вот оно! В MainStoryboard.storyboard, кнопка связана с bookmarkButtonPressed: вместо bookmarkButtonPressed (обратите внимание на двоеточие в конце, которое говорит о том, что у метода есть параметр). Чтобы это исправить, замените название метода на такой:

Конечно, вы можете просто удалить связь с неправильным методом в XIB-файле и связать событие к правильным методом. В любом случае сработает.
И вот ещё одна причина аварийного останова устранена.

Сценарий 3. Закладкой больше, закладкой меньше.

Ещё одна жалоба от пользователя: «Я не могу удалить закладку на персонажа из окна закладок. «. И ещё одно письмо о том же: «Если я пытаюсь удалить персонажа из закладок, приложение падает. «

К этому моменту, вы уже привыкли, что письма от пользователей не бывают полезными. К аварийным журналам!

Этот журнал очень похож на предыдущий аварийный журнал. Тут тоже SIGABRT исключение. Может тут та же причина: отправка сообщения объекту, у которого не реализован метод?

Давайте посмотрим трассировку, какие методы вызывались. Начните с нижней части. Последний вызов на ваш код в Rage Masters был в фрейме №6:

Это вызов метода UITableViewDataSource. И что? Если вы не уверены, что компания Apple реализовала этот метод — можете переписать его, но не похоже, что это так. Кроме того, это дополнительный, не обязательный метод делегата. Так что проблема не в вызове нереализованного метода.

Посмотрим на фреймы дальше:

В фрейме №5, UITableView вызывает другой собственный метод, deleteRowsAtIndexPaths:withRowAnimation: а потом вызывается _endCellAnimationsWithContext:, который выглядит как внутренний метод Apple. Затем, происходит исключение фреймворка Foundation, handleFailureInMethod:object:file:lineNumber:description:.

Если собрать это вместе с жалобами пользователей, то это выглядит так, как будто вы имеете дело с ошибкой в процедуре удаления UITableView. Идём в Xcode. Вы знаете, куда идти? Может ли это сказать нам аварийный журнал? Смотрим строку №68 в RMBookmarksViewController.m:

Нашли, где проблема? Я буду ждать, пока вы не найдёте.

Кто-то забыл про источник данных! Код удаляет строку в представлении, но не меняет источник данных. Чтобы это исправить, замените код на следующий:

Вот так будет с каждой ошибкой! Бац! Бах! Бум!

Сценарий 4. Леденец

Письмо: «Мое приложение падает, когда персонаж лижет леденец. «. Другой пользователь: «Я нажимаю кнопку «Лизнуть леденец» несколько раз, а затем приложение вылетает!»

Вот аварийный журнал:

Этот журнал очень отличается от тех, что мы видели до сих пор!

Это аварийный журнал нехватки памяти iOS 6. Как уже говорилось ранее, аварийный журнал нехватки памяти отличается от других аварийных журналов, потому что он не указывает на конкретный файл или строку кода. Вместо этого, он рисует картину, сложившуюся в памяти устройства в момент ситуации, которая привела к аварийному останову.

Заголовок, впрочем, похож на заголовок обычного аварийного журнала: те же поля Incident Identifier, CrashReporter Key, Hardware Model, OS Version и другие.

Вот следующий раздел специфичен только для аварийный журнал нехватки памяти:

  • Free pages – количество свободной памяти в страницах. Каждая страница соотвествтвует примерно 4КБ, поэтому наш журнал говорит о свободной памяти в размере около 3 872 КБ (или 3,9 МБ).
  • Purgeable pages – часть памяти, которая может быть очищена от предыдущего использования и снова использована. В нашем журнале её 0 КБ.
  • Largest process – имя приложения, которое использовало самое большое количество памяти на момент аварийного останова, и там написано наше приложение!
  • Processes — список процессов, а также как они использовали память во время аварии. Тут имя процесса (первый столбец), уникальный идентификатор процесса (второй столбец) и количество страниц, используемых в процессе (третий столбец). В последнем столбце (State), вы видите состояние каждого приложения. Как правило, приложения, которые привели к аварийному останову находятся в состоянии frontmost. И тут наш Rage Masters, который использует 28591 страниц (или 114 364 МБ) — это много памяти!

Как правило, самый большой процесс и процесс в состоянии frontmost – это один и тот же процесс, а также это тот процесс, который привел к аварийному останову из-за нехватки памяти. Но вы можете увидеть некоторые случаи, когда крупнейшие процессы и процессы в состоянии frontmost – это не то же самое. Например, если вы видите, что больше всего памяти потребляет процесс SpringBoard, можете игнорировать его, потому что SpringBoard — это главный процесс, отвечающий за главный экран в Apple iOS. С него запускаются и загружаются все установленные приложения. Он всегда активен.

При нехватке памяти iOS посылает предупреждение о низком уровне памяти активному приложению и завершает фоновые процессы. Если активное приложение продолжает увеличивать использование памяти, iOS завершает его.

Чтобы найти причину проблем с нехваткой памяти, необходимо профилировать приложение, используя утилиту Instruments. Если вы не знаете, как это делать, есть учебник. Вместо этого, мы решим проблему «в лоб», просто обработаем в нашей программе событие о нехватке памяти.
Перейдите в Xcode в RMLollipopLicker.m. Это там реализован контроллер представления лизания леденца. Взгляните на исходный код:

Когда пользователь нажимает кнопку запуска, приложение запускает в фоновом режиме процедуру lickLollipop несколько раз, а затем обновляет на экране количество лизаний. lickLollipop читает большую строку NSString из PLIST-файла и добавляет её в массив. Эти данные не критичны, и могут быть воссозданы, не влияя на работу пользователей.

Заведите хорошую привычку — пользоваться любой ситуацией, когда можно очистить данные, которые можно потом восстановить без ущерба для пользователей. Так вы освобождаете память, что делает вероятность появления предупреждений о нехватке памяти менее вероятной.
Итак, как можно улучшить код в нашем случае? Реализовать didReceiveMemoryWarning и избавиться от данных в массиве lollipops:

И всё будет хорошо!

Что дальше?

Ура, вы прошли через все четыре сценария развития аварийных ситуаций! Ваше приложение работает намного лучше, и вы получили важные навыки отладки по ходу обучения.

Источник

If any iOS app crashes some crash logs are generated on behalf of that app.
How to find the location of such crash logs. Please help.

I want crash logs inside the iPhone/iPad, not really using XCode to see the crash logs.

asked Jun 25, 2014 at 4:51

user249605's user avatar

user249605user249605

2292 gold badges3 silver badges8 bronze badges

you can find crash report on iPad/iphone below location for iOS:

IOS7 & Below = Settings —> General —> About —> Diagnostics & Usage —> Diagnotstic & Usage Data

IOS8 & IOS9 = Settings —> Privacy —> Diagnostics & Usage —> Diagnotstic & Usage Data

IOS10 & Above = Settings —> Privacy —> Analytics —> Analytics Data

answered Apr 8, 2015 at 9:52

Jashu's user avatar

JashuJashu

1,04113 silver badges19 bronze badges

1

I think he/she asked about crash logs inside the iPhone/iPad, not really using XCode to see the crash logs.

To check the crash logs inside iPhone/iPad, you have to go to

Settings -> General -> About -> Diagnostics & Usage -> Diagnostic & Usage Data

You will see the crash log with the Title APPName_Date….

Attached the screen shot of one of the crash logs below:-

enter image description here

answered Jun 25, 2014 at 5:16

Ricky's user avatar

RickyRicky

10.5k6 gold badges36 silver badges49 bronze badges

0

👉 https://support.apple.com/en-in/HT202100

IOS 7 & Below = Settings —> General —> About —> Diagnostics & Usage —> Diagnotstic & Usage Data

IOS 8 & Above = Settings —> Privacy —> Diagnostics & Usage —> Diagnotstic & Usage Data

IOS 10.2 = Settings —> Privacy —>Analytics —> Diagnotstic & Usage Data

IOS 10.3.2 and Above = Settings —> Privacy —> Analytics —> Analytics Data

enter image description here

answered May 2, 2017 at 5:06

MAhipal Singh's user avatar

MAhipal SinghMAhipal Singh

4,7451 gold badge42 silver badges56 bronze badges

1

From Apple Docs:

Even though you won’t be able to run the app in Xcode’s debugger, Xcode can still give you all the information you need to debug the problem.

1) Plug in the device and open Xcode

2) Open the Organizer window and select the Devices tab

3) Under the DEVICES section in the left column, expand the listing for the device

4) Select Device Logs to see crash logs or select Console to see Console output

OR
enter image description here

answered Jun 25, 2014 at 4:55

Himanshu A Jadav's user avatar

2


Download Article


Download Article

This wikiHow teaches you how to view diagnostic files that contain detailed information about crashes and memory issues on your iPhone.

  1. Image titled View Your Diagnostics and Usage Data on an iPhone Step 1

    1

    Open your iPhone’s Settings. It’s an app with a gray cog on one of your home screens. It might be in a folder called “Utilities.”

  2. Image titled View Your Diagnostics and Usage Data on an iPhone Step 2

    2

    Scroll down and tap Privacy. It’s in the third section.

    Advertisement

  3. Image titled View Your Diagnostics and Usage Data on an iPhone Step 3

    3

    Scroll down and tap Diagnostics & Usage. It’s at the bottom of the menu.[1]

  4. Image titled View Your Diagnostics and Usage Data on an iPhone Step 4

    4

    Tap Diagnostics & Usage Data.

  5. Image titled View Your Diagnostics and Usage Data on an iPhone Step 5

    5

    Tap an entry to view diagnostic data.

    • Logs for specific apps begin with the app’s name, followed by the date (e.g. “Evernote-2016-12-27”).
    • Entries that begin with “JetsamEvent” are created when apps and data have memory (RAM) issues.
    • Entries that begin with “Stacks” don’t represent crashes. They just contain information about iOS.
  6. Advertisement

Add New Question

  • Question

    I do not see diagnostic and usage data, only analytics data. Any ideas?

    Community Answer

    Go into your data settings and go down to the bottom, it will all be there.

Ask a Question

200 characters left

Include your email address to get a message when this question is answered.

Submit

Advertisement

  • These diagnostic files contain highly technical information about hardware and operating system issue, so they may not be helpful to novices.

  • You can help Apple improve its services by choosing to automatically send them copies of your diagnostic logs. In the Diagnostics & Usage area of your Privacy settings, select Automatically Send.

Thanks for submitting a tip for review!

Advertisement

About This Article

Article SummaryX

1. Open your Settings.
2. Tap Privacy.
3. Tap Diagnostics & Usage.
4. Tap Diagnostics & Usage Data.
5. Tap an entry to view diagnostic information.

Did this summary help you?

Thanks to all authors for creating a page that has been read 72,265 times.

Is this article up to date?

Поиск журналов сбоев на устройствах iOS

Если вы устраняете сбои приложения, бета-тестируете приложение или просто хотите помочь разработчику iOS после обнаружения конкретной ошибки, вы можете получать отчеты о сбоях из любого приложения на устройстве iPhone, iPad или iPod touch. как только он будет синхронизирован с компьютером.

Поиск данных отчета о сбоях для iOS можно выполнить вне Xcode, если в любом случае вы сделаете резервную копию устройства на компьютер. В статье показано, как найти журналы сбоев iOS в Mac OS X и ПК с Windows.

Доступ к журналам сбоев iOS на Mac

Для Mac OS X:

  • Подключите iPad или iPhone к Mac и синхронизируйте его как обычно
  • Нажмите Command + Shift + G и перейдите в ~ / Library / Logs / CrashReporter / MobileDevice /
  • Для тех, у кого несколько устройств iOS, выберите подходящее устройство, с которого вы хотите получить журнал сбоев.
  • Найдите файлы с именем приложения, из которого вы хотите получать отчеты о сбоях, скопируйте их из папки или скопируйте несколько журналов и заархивируйте их для разработчика.

Журнал сбоев iOS

Получение отчетов о сбоях iPhone и iPad на ПК с Windows

Для ПК с Windows:

  • Синхронизируйте устройство iOS с iTunes, затем посмотрите в следующих местах:
    • Windows XP: C: Documents and Settings USER Application Data Apple computer Logs CrashReporter
    • Windows Vista и Windows 7: C: Users USER AppData Roaming Apple computer Logs CrashReporter MobileDevice
  • Найдите соответствующее имя устройства, затем найдите файл по имени приложения и отметке времени.

Независимо от того, получаете ли вы журнал сбоев с ПК или Mac, если устройство такое же, данные журнала сбоев должны быть одинаковыми.

Благодаря TC за подсказку, дополнительную информацию можно найти на Библиотека Apple Dev.

логи прошивки это просто подробная инфа ошибок,т.е. окошко на котором в тюнце выскочила ошибка -1,это понятие ростяжимое и только извесно что проблема в модемной части,либо нет питания модема либо епром и т п,по нею кроются еще много ошибок которые подсказывают намного точнее куда копать,а вот как раз в логах и кроются эти подсказки,можна и ошибку 50 увидеть и еще кучу всяких,типа 27,28,вот кто много перебрал афоней,тот уже почти на изусть знает,все приходит с опытом,нужно знать где когда и какие напруги должны быть,и даже при прошивке они вичисляются легко,и даже если ошибка -1,это далеко не значит что проблема в модемном проце,просто банально нет питания бб,а тут и ошибка в логах подскажет (ошибка 50) а не строго -1,потому он не отзывается при прошивке…я во многих темах детально описывал разные шаги по разных ошибках…а еще очень полезно знать поочередность прошиваемых частей ТА,это минимум который должен знать любой мастер,а уж тогда изучать ошибки и их логи.

Понравилась статья? Поделить с друзьями:
  • Ошибки айкос 3 дуос мигает
  • Ошибки адресации массивов
  • Ошибки адольфа гитлера
  • Ошибки администратора салона красоты
  • Ошибки администратора гостиницы