問題描述
最近做混淆扑媚,發(fā)現(xiàn)腰湾,即使你開了混淆,某些類名稱疆股,依舊沒有被改變费坊,這部分的代碼,又剛剛好是協(xié)程寫的
問題測試調(diào)研
class TestLunch{
val defaultScope = CoroutineScope(Dispatchers.Default)
fun helloWorld() {
defaultScope.launch {
System.out.println("Hello, world!")
}
}
}
image.png
我們對上面的代碼進(jìn)行反編譯旬痹,發(fā)現(xiàn)會變成靜態(tài)內(nèi)部類附井,且繼承了SuspendLambda,SuspendLambda怎么來的两残?其實(shí)我們寫協(xié)程的時(shí)候就是調(diào)用了擴(kuò)展方法
public fun CoroutineScope.launch(
context: CoroutineContext = EmptyCoroutineContext,
start: CoroutineStart = CoroutineStart.DEFAULT,
block: suspend CoroutineScope.() -> Unit
): Job {
val newContext = newCoroutineContext(context)
val coroutine = if (start.isLazy)
LazyStandaloneCoroutine(newContext, block) else
StandaloneCoroutine(newContext, active = true)
coroutine.start(start, coroutine, block)
return coroutine
}
編譯器會幫我們將帶有suspend標(biāo)識的永毅,去繼承 SuspendLambda,我們繼續(xù)去追蹤SuspendLambda的父類人弓,結(jié)果發(fā)現(xiàn)最終的父類 BaseContinuationImpl 去 implements Serializable
image.png
可以看見類名字被保留了下來,后面無意間發(fā)現(xiàn)票从,混淆文件里面有配置
#保持 Serializable 不被混淆
-keepnames class * implements java.io.Serializable