在Android中, 我们天天使用adb确没有发现 其有点小差别。
遇到个问题,就是没有像往常一样看到我们的log输出。
平时都是用adb logcat, 其logcat是打印 main 和 system 的log
而 adb logcat -b main 只是单纯的打出main log.
探究其代码发现果真如此:
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++;
}