ReflectionFactory - kt
变更记录
v1.0.0 添加
功能描述
这是自定义
Member和Class相关功能的查找匹配以及invoke的封装类。
LazyClass - class
open class LazyClass<T> internal constructor(
private val instance: Any,
private val initialize: Boolean,
private val loader: ClassLoaderInitializer?
)
变更记录
v1.0.3 新增
功能描述
懒装载
Class实例。
ClassLoader.listOfClasses - ext-method
fun ClassLoader.listOfClasses(): List<String>
变更记录
v1.0.0 添加
功能描述
写出当前
ClassLoader下所有Class名称数组。
ClassLoader.searchClass - ext-method
inline fun ClassLoader.searchClass(context: Context?, name: String, async: Boolean, initiate: ClassConditions): DexClassFinder.Result
变更记录
v1.0.0 添加
功能描述
通过当前
ClassLoader按指定条件查找并得到 Dex 中的Class。
特别注意
此方法在 Class 数量过多及查找条件复杂时会非常耗时。
建议启用 async 或设置 name 参数,name 参数将在当前 APP 不同版本中自动进行本地缓存以提升效率。
如果使用了 async 或 name 参数,则必须填写 context 参数。
此功能尚在试验阶段,性能与稳定性可能仍然存在问题,使用过程遇到问题请向我们报告并帮助我们改进。
Class.hasExtends - ext-field
val Class<*>.hasExtends: Boolean
变更记录
v1.0.0 添加
功能描述
当前
Class是否有继承关系,父类是Any将被认为没有继承关系。
Class?.extends - ext-method
infix fun Class<*>?.extends(other: Class<*>?): Boolean
变更记录
v1.0.0 添加
功能描述
当前
Class是否继承于other。
如果当前 Class 就是 other 也会返回 true。
如果当前 Class 为 null 或 other 为 null 会返回 false。
功能示例
你可以使用此方法来判断两个 Class 是否存在继承关系。
示例如下
// 假设下面这两个 Class 就是你需要判断的 Class
val classA: Class<*>?
val classB: Class<*>?
// 判断 A 是否继承于 B
if (classA extends classB) {
// Your code here.
}
Class?.notExtends - ext-method
infix fun Class<*>?.notExtends(other: Class<*>?): Boolean
变更记录
v1.0.0 添加
功能描述
当前
Class是否不继承于other。
此方法相当于 extends 的反向判断。
功能示例
你可以使用此方法来判断两个 Class 是否不存在继承关系。
示例如下
// 假设下面这两个 Class 就是你需要判断的 Class
val classA: Class<*>?
val classB: Class<*>?
// 判断 A 是否不继承于 B
if (classA notExtends classB) {
// Your code here.
}
Class?.implements - ext-method
infix fun Class<*>?.implements(other: Class<*>?): Boolean
变更记录
v1.0.0 添加
功能描述
当前
Class是否实现了other接口类。
如果当前 Class 为 null 或 other 为 null 会返回 false。
功能示例
你可以使用此方法来判断两个 Class 是否存在依赖关系。
示例如下
// 假设下面这两个 Class 就是你需要判断的 Class
val classA: Class<*>?
val classB: Class<*>?
// 判断 A 是否实现了 B 接口类
if (classA implements classB) {
// Your code here.
}
Class?.notImplements - ext-method
infix fun Class<*>?.notImplements(other: Class<*>?): Boolean
变更记录
v1.0.0 添加
功能描述
当前
Class是否未实现other接口类。
此方法相当于 implements 的反向判断。
功能示例
你可以使用此方法来判断两个 Class 是否不存在依赖关系。
示例如下
// 假设下面这两个 Class 就是你需要判断的 Class
val classA: Class<*>?
val classB: Class<*>?
// 判断 A 是否未实现 B 接口类
if (classA notImplements classB) {
// Your code here.
}
Class.toJavaPrimitiveType - ext-method
fun Class<*>.toJavaPrimitiveType(): Class<*>
变更记录
v1.0.0 添加
功能描述
自动转换当前
Class为 Java 原始类型 (Primitive Type)。
如果当前 Class 为 Java 或 Kotlin 基本类型将自动执行类型转换。
当前能够自动转换的基本类型如下。
kotlin.Unitjava.lang.Voidjava.lang.Booleanjava.lang.Integerjava.lang.Floatjava.lang.Doublejava.lang.Longjava.lang.Shortjava.lang.Characterjava.lang.Byte
String.toClass - ext-method
fun String.toClass(loader: ClassLoader?, initialize: Boolean): Class<*>
inline fun <reified T> String.toClass(loader: ClassLoader?, initialize: Boolean): Class<T>
变更记录
v1.0.0 添加
功能描述
通过字符串类名转换为
loader中的实体类。
功能示例
你可以直接填写你要查找的目标 Class,必须在默认 ClassLoader 下存在。
示例如下
"com.example.demo.DemoClass".toClass()
你还可以自定义 Class 所在的 ClassLoader。
示例如下
val customClassLoader: ClassLoader? = ... // 假设这个就是你的 ClassLoader
"com.example.demo.DemoClass".toClass(customClassLoader)
你还可以指定 Class 的目标类型。
示例如下
// 指定的 DemoClass 必须存在或为可访问的 stub
"com.example.demo.DemoClass".toClass<DemoClass>()
你还可以设置在获取到这个 Class 时是否自动执行其默认的静态方法块,默认情况下不会执行。
示例如下
// 获取并执行 DemoClass 默认的静态方法块
"com.example.demo.DemoClass".toClass(initialize = true)
默认的静态方法块在 Java 中使用如下方式定义。
示例如下
public class DemoClass {
static {
// 这里是静态方法块的内容
}
public DemoClass() {
// ...
}
}
String.toClassOrNull - ext-method
fun String.toClassOrNull(loader: ClassLoader?, initialize: Boolean): Class<*>?
inline fun <reified T> String.toClassOrNull(loader: ClassLoader?, initialize: Boolean): Class<T>?
变更记录
v1.0.0 添加
功能描述
通过字符串类名转换为
loader中的实体类。
找不到 Class 会返回 null,不会抛出异常。
功能示例
用法请参考 String.toClass 方法。
classOf - method
inline fun <reified T> classOf(loader: ClassLoader?, initialize: Boolean): Class<T>
变更记录
v1.0.0 添加
功能描述
通过
T得到其Class实例并转换为实体类。
功能示例
我们要获取一个 Class 在 Kotlin 下不通过反射时应该这样做。
示例如下
DemoClass::class.java
现在,你可以直接 cast 一个实例并获取它的 Class 对象,必须在当前 ClassLoader 下存在。
示例如下
classOf<DemoClass>()
若目标存在的 Class 为 stub,通过这种方式,你还可以自定义 Class 所在的 ClassLoader。
示例如下
val customClassLoader: ClassLoader? = ... // 假设这个就是你的 ClassLoader
classOf<DemoClass>(customClassLoader)
lazyClass - method
fun lazyClass(name: String, initialize: Boolean, loader: ClassLoaderInitializer?): LazyClass.NonNull<Any>
inline fun <reified T> lazyClass(name: String, initialize: Boolean, loader: ClassLoaderInitializer?): LazyClass.NonNull<T>
fun lazyClass(variousClass: VariousClass, initialize: Boolean, loader: ClassLoaderInitializer?): LazyClass.NonNull<Any>
变更记录
v1.0.3 新增
功能描述
懒装载
Class。
lazyClassOrNull - method
fun lazyClassOrNull(name: String, initialize: Boolean, loader: ClassLoaderInitializer?): LazyClass.Nullable<Any>
inline fun <reified T> lazyClassOrNull(name: String, initialize: Boolean, loader: ClassLoaderInitializer?): LazyClass.Nullable<T>
fun lazyClassOrNull(variousClass: VariousClass, initialize: Boolean, loader: ClassLoaderInitializer?): LazyClass.Nullable<Any>
变更记录
v1.0.3 新增
功能描述
懒装载
Class。
String.hasClass - ext-method
fun String.hasClass(loader: ClassLoader?): Boolean
变更记录
v1.0.0 添加
功能描述
通过字符串类名使用指定的
ClassLoader查找是否存在。
功能示例
你可以轻松的使用此方法判断字符串中的类是否存在,效果等同于直接使用 Class.forName。
示例如下
if("com.example.demo.DemoClass".hasClass()) {
// Your code here.
}
填入方法中的 loader 参数可判断指定的 ClassLoader 中的 Class 是否存在。
示例如下
val customClassLoader: ClassLoader? = ... // 假设这个就是你的 ClassLoader
if("com.example.demo.DemoClass".hasClass(customClassLoader)) {
// Your code here.
}
Class.hasField - ext-method
inline fun Class<*>.hasField(initiate: FieldConditions): Boolean
变更记录
v1.0.0 添加
功能描述
查找变量是否存在。
Class.hasMethod - ext-method
inline fun Class<*>.hasMethod(initiate: MethodConditions): Boolean
变更记录
v1.0.0 添加
功能描述
查找方法是否存在。
Class.hasConstructor - ext-method
inline fun Class<*>.hasConstructor(initiate: ConstructorConditions): Boolean
变更记录
v1.0.0 添加
功能描述
查找构造方法是否存在。
Member.hasModifiers - ext-method
inline fun Member.hasModifiers(conditions: ModifierConditions): Boolean
变更记录
v1.0.0 添加
功能描述
查找
Member中匹配的描述符。
Class.hasModifiers - ext-method
inline fun Class<*>.hasModifiers(conditions: ModifierConditions): Boolean
变更记录
v1.0.0 添加
功能描述
查找
Class中匹配的描述符。
Class.field - ext-method
inline fun Class<*>.field(initiate: FieldConditions): FieldFinder.Result
变更记录
v1.0.0 添加
功能描述
查找并得到变量。
Class.method - ext-method
inline fun Class<*>.method(initiate: MethodConditions): MethodFinder.Result
变更记录
v1.0.0 添加
功能描述
查找并得到方法。
Class.constructor - ext-method
inline fun Class<*>.constructor(initiate: ConstructorConditions): ConstructorFinder.Result
变更记录
v1.0.0 添加
功能描述
查找并得到构造方法。
Class.generic - ext-method
fun Class<*>.generic(): GenericClass?
变更记录
v1.0.0 添加
功能描述
获得当前
Class的泛型父类。
如果当前实例不存在泛型将返回 null。
Class.generic - ext-method
inline fun Class<*>.generic(initiate: GenericClass.() -> Unit): GenericClass?
变更记录
v1.0.0 添加
功能描述
获得当前
Class的泛型父类。
如果当前实例不存在泛型将返回 null。
Any.current - ext-method
inline fun <reified T : Any> T.current(ignored: Boolean): CurrentClass
inline fun <reified T : Any> T.current(ignored: Boolean, initiate: CurrentClass.() -> Unit): T
变更记录
v1.0.0 添加
功能描述
获得当前实例的类操作对象。
Class.buildOf - ext-method
inline fun Class<*>.buildOf(vararg args: Any?, initiate: ConstructorConditions): Any?
inline fun <T> Class<*>.buildOf(vararg args: Any?, initiate: ConstructorConditions): T?
变更记录
v1.0.0 添加
功能描述
通过构造方法创建新实例,指定类型
T或任意类型Any。
Class.allMethods - ext-method
inline fun Class<*>.allMethods(isAccessible: Boolean, result: (index: Int, method: Method) -> Unit)
变更记录
v1.0.0 添加
功能描述
遍历当前类中的所有方法。
Class.allConstructors - ext-method
inline fun Class<*>.allConstructors(isAccessible: Boolean, result: (index: Int, constructor: Constructor<*>) -> Unit)
变更记录
v1.0.0 添加
功能描述
遍历当前类中的所有构造方法。
Class.allFields - ext-method
inline fun Class<*>.allFields(isAccessible: Boolean, result: (index: Int, field: Field) -> Unit)
变更记录
v1.0.0 添加
功能描述
遍历当前类中的所有变量。
