У меня есть класс, в котором я выполняю некоторое сканирование аннотаций во время выполнения, но он использует устаревшие API DexFile , что приводит к появлению предупреждения в LogCat:
W/zygote64: Opening an oat file without a class loader. Are you using the deprecated DexFile APIs?
.
Я бы хотел избавиться от этого сообщения и использовать соответствующие API. Документы предлагают PathClassLoader
, но я не вижу, как это эквивалентно DexFile
по функциональности. Я могу использовать PathClassLoader
в сочетании с экземпляром DexFile
, и, хотя он работает, он дает мне еще больше предупреждений и занимает больше времени на сканирование. Я включил сканер аннотаций, который я написал ниже для ясности. Если кто-нибудь может подсказать, как избавиться от этих предупреждающих сообщений и альтернативы DexFile
, чтобы я не столкнулся с нарушенной функциональностью после ее удаления, я был бы очень признателен.
class AnnotationScanner {
companion object {
fun classesWithAnnotation(
context: Context,
annotationClass: Class<out Annotation>,
packageName: String? = null
): Set<Class<*>> {
return Pair(context.packageCodePath, context.classLoader)
.letAllNotNull { packageCodePath, classLoader ->
Pair(DexFile(packageCodePath), classLoader)
}
?.letAllNotNull { dexFile, classLoader ->
dexFile
.entries()
?.toList()
?.filter { entry ->
filterByPackageName(packageName, entry)
}
?.map {
dexFile.loadClass(it, classLoader)
}
?.filter { aClass ->
filterByAnnotation(aClass, annotationClass)
}
?.toSet()
} ?: emptySet<Class<*>>().wlog { "No ${annotationClass.simpleName} annotated classes found" }
}
private fun filterByAnnotation(aClass: Class<*>?, annotationClass: Class<out Annotation>): Boolean {
return aClass
?.isAnnotationPresent(annotationClass)
?.also {
it.ifTrue {
Timber.w("Found ${annotationClass.simpleName} on $aClass")
}
}
?: false
}
private fun filterByPackageName(packageName: String?, entry: String) =
packageName?.let { entry.toLowerCase().startsWith(it.toLowerCase()) } ?: true
}
}