区别adb logcat 与 adb logcat -b main

在Android中, 我们天天使用adb确没有发现 其有点小差别。

遇到个问题,就是没有像往常一样看到我们的log输出。

平时都是用adb logcat, 其logcat是打印 main 和 system 的log

而 adb logcat -b main 只是单纯的打出main log.

探究其代码发现果真如此:

system/core/logcat/logcat.cpp

    if (!devices) {
        devices = new log_device_t(strdup("/dev/"LOGGER_LOG_MAIN), false, LOGGER_LOG_MAIN[0]);
         devices = new log_device_t(strdup("/dev/"LOGGER_LOG_MAIN), false, 'm');
          android::g_devCount = 1;
         int accessmode =
                   (mode & O_RDONLY) ? R_OK : 0
                 | (mode & O_WRONLY) ? W_OK : 0;
         // only add this if it's available
         if (0 == access("/dev/"LOGGER_LOG_SYSTEM, accessmode)) {
             devices->next = new log_device_t(strdup("/dev/"LOGGER_LOG_SYSTEM), false, 's');// 用链表把main和system链到一起 最后通过函数android::readLogLines(devices);一起输出
             android::g_devCount++;
         }



你可能感兴趣的:(android)