Android, как распечатать идентификатор или имя COROUTINE в пользовательской функции журналаAndroid

Форум для тех, кто программирует под Android
Ответить
Anonymous
 Android, как распечатать идентификатор или имя COROUTINE в пользовательской функции журнала

Сообщение Anonymous »

Я хочу изменить эту функцию вспомогательного журнала, чтобы распечатать идентификатор или имени Coroutine. < /p>

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

   @JvmInline
value class MyLogger(private val tag: String) {
fun log(level: Level, e: Throwable? = null, message: String) {
if (isLoggingEnabled(level)) {
val logTime = System.currentTimeMillis()
val messageWithCoroutineInfo = "Running on: [${Thread.currentThread().name}] | $message"
when (level) {
Level.VERBOSE -> Log.v(tag, messageWithCoroutineInfo, e)
Level.DEBUG -> Log.d(tag, messageWithCoroutineInfo, e)
Level.INFO -> Log.i(tag, messageWithCoroutineInfo, e)
Level.WARN -> Log.w(tag, messageWithCoroutineInfo, e)
Level.ERROR -> Log.e(tag, messageWithCoroutineInfo, e)
Level.ASSERT -> Log.wtf(tag, messageWithCoroutineInfo, e)
}
}
}
....
}

private val logger = MYLogger("Navigator")
logger.i { "goTo: $screen; backstack: [${backStack.joinToString()}]" }
< /code>
В функции Oncreate: < /p>
    override fun onCreate(savedInstanceState: Bundle?) {

super.onCreate(savedInstanceState)
System.setProperty("kotlinx.coroutines.debug", if(!BuildTypes.isProduction) "on" else "off")
он может распечатать имя потока, но он не может распечатать идентификатор или имя Coroutine, например [awt-eventqueue-0 @coroutine#40], любое предложение?

Подробнее здесь: https://stackoverflow.com/questions/794 ... g-function
Ответить

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

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

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

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

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