Почему logcat в Android Studio не выводит полностью логи? - PullRequest
0 голосов
/ 28 декабря 2018

Я использую цикл для вывода журнала, но не все оно полностью напечатано в logcat, и некоторая недостающая информация журнала не отображается.Как я могу вывести всю информацию полностью?

for (int i=0;i<(mSpaceCount + mPulseCount);i++)
{
    Log.i("flag", "~~~~m_bitDateF[i] : "+m_bitDateF[i]+" i :"+i);
}

Вывод выглядит следующим образом:

............

12-28 18:43:24.215 20116 20503 I flag    : ~~~~m_bitDateF[i] : -3.5 i :434
12-28 18:43:24.215 20116 20503 I flag    : ~~~~m_bitDateF[i] : -3.5 i :435
12-28 18:43:24.215 20116 20503 I flag    : ~~~~m_bitDateF[i] : -3.5 i :436
12-28 18:43:24.215 20116 20503 I flag    : ~~~~m_bitDateF[i] : -3.5 i :437
12-28 18:43:24.215 20116 20503 I flag    : ~~~~m_bitDateF[i] : -3.5 i :438
12-28 18:43:24.215 20116 20503 I flag    : ~~~~m_bitDateF[i] : -3.5 i :439
12-28 18:43:24.215 20116 20503 I flag    : ~~~~m_bitDateF[i] : 3.5 i :440
12-28 18:43:24.215 20116 20503 I flag    : ~~~~m_bitDateF[i] : 3.5 i :441
12-28 18:43:24.215 20116 20503 I flag    : ~~~~m_bitDateF[i] : 3.5 i :442
12-28 18:43:24.215 20116 20503 I flag    : ~~~~m_bitDateF[i] : 3.5 i :443
12-28 18:43:24.215 20116 20503 I flag    : ~~~~m_bitDateF[i] : 3.5 i :444
12-28 18:43:24.215 20116 20503 I flag    : ~~~~m_bitDateF[i] : 3.5 i :445
12-28 18:43:24.215 20116 20503 I flag    : ~~~~m_bitDateF[i] : 3.5 i :446
12-28 18:43:24.216 20116 20503 I flag    : ~~~~m_bitDateF[i] : 3.5 i :447
12-28 18:43:24.216 20116 20503 I flag    : ~~~~m_bitDateF[i] : 3.5 i :448
12-28 18:43:24.216 20116 20503 I flag    : ~~~~m_bitDateF[i] : 3.5 i :449
12-28 18:43:24.219 20116 20503 I flag    : ~~~~m_bitDateF[i] : 3.5 i :601
12-28 18:43:24.219 20116 20503 I flag    : ~~~~m_bitDateF[i] : 3.5 i :604
12-28 18:43:24.222 20116 20503 I flag    : ~~~~m_bitDateF[i] : -3.5 i :749
12-28 18:43:24.222 20116 20503 I flag    : ~~~~m_bitDateF[i] : -3.5 i :756
12-28 18:43:24.222 20116 20503 I flag    : ~~~~m_bitDateF[i] : -3.5 i :757
12-28 18:43:24.222 20116 20503 I flag    : ~~~~m_bitDateF[i] : -3.5 i :758
12-28 18:43:24.222 20116 20503 I flag    : ~~~~m_bitDateF[i] : -3.5 i :759
12-28 18:43:24.222 20116 20503 I flag    : ~~~~m_bitDateF[i] : -3.5 i :760
12-28 18:43:24.222 20116 20503 I flag    : ~~~~m_bitDateF[i] : -3.5 i :761
12-28 18:43:24.222 20116 20503 I flag    : ~~~~m_bitDateF[i] : -3.5 i :762
12-28 18:43:24.222 20116 20503 I flag    : ~~~~m_bitDateF[i] : -3.5 i :763
12-28 18:43:24.222 20116 20503 I flag    : ~~~~m_bitDateF[i] : -3.5 i :764
12-28 18:43:24.222 20116 20503 I flag    : ~~~~m_bitDateF[i] : -3.5 i :765
12-28 18:43:24.224 20116 20503 I flag    : ~~~~m_bitDateF[i] : -3.5 i :837
12-28 18:43:24.224 20116 20503 I flag    : ~~~~m_bitDateF[i] : -3.5 i :838
12-28 18:43:24.224 20116 20503 I flag    : ~~~~m_bitDateF[i] : -3.5 i :839
12-28 18:43:24.224 20116 20503 I flag    : ~~~~m_bitDateF[i] : -3.5 i :840
12-28 18:43:24.224 20116 20503 I flag    : ~~~~m_bitDateF[i] : -3.5 i :841

............

Вы можете видеть, что вывод был пропущен после 449-601 и 604-749, ноцикл должен быть выполнен, но нет вывода.Я не знаю, почему не все выходные данные, и проблема случайная, и иногда она будет выводиться нормально.Как сделать logcat полным выходным журналом?

1 Ответ

0 голосов
/ 28 декабря 2018

Глядя на свой Logcat, вы должны посмотреть на отметку времени слева.18:43:24.215 например..215 - это миллисекунды.И если вы посмотрите на вывод, оканчивающийся на одну и ту же миллисекунду, вы увидите, что вы выводите около 20 строк вывода в миллисекунду.

Теперь, глядя на ваш вывод, где вы пропускаете числа, посмотрите на миллисекунды.

18:43:24.215 : i :446
18:43:24.216 : i :447
18:43:24.216 : i :448
18:43:24.216 : i :449
// it's skipping here //
18:43:24.219 : i :601
18:43:24.219 : i :604

Он пропустил около 3 миллисекунд.

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

Если вы действительно хотите выйти из этой информации, вам нужно изменить способ регистрации.

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

// Create a String to hold all the log information.
String log = "";

for (int i=0 ;i < (mSpaceCount + mPulseCount); i++) {
    // Append the log information to our String. 
    // Add a "\n" to add a new line at the end of each line.
    log += "~~~~m_bitDateF[i] : " + m_bitDateF[i] + " i :" + i + "\n";
}

// Finally, log the output.
Log.i("flag", log);
...