android studio apply,android jvmti 应用之实现android studio 3.5 apply change功能(不重启的热修复哦)...

上一篇使用了jvmti 完成了计算objecSize的功能,这次重点介绍一下如何实现android studio 3.5 apply change 功能,即如何在不重启应用的前提下运行时修改class,这里提一点android jvmti 是android p才开始提供的,然后只能运用于debug

1. 效果图

AAffA0nNPuCLAAAAAElFTkSuQmCC

AAffA0nNPuCLAAAAAElFTkSuQmCC

out.dex中存放着修复之后的Test.class log输出为 修复的Test,然后最爽的一点是运行时修改class,无需重启哟~!!!

2. show code

button_modify_class.setOnClickListener {

// redefineClass:对于已经加载的类重新进行转换处理,即会触发重新加载类定义,

// 需要注意的是,新加载的类不能修改旧有的类声明,譬如不能增加属性、不能修改方法声明

Test().log()

JVMTIHelper.init(this@MainActivity)

//dexbyte

val dexbyte = getBytes(assets.open("out.dex"))

JVMTIHelper.redefineClass(Test::class.java, dexbyte)

Test().log()

}

重点就是这句话JVMTIHelper.redefineClass(Test::class.java, dexbyte)调用了jni封装的jvmti的redefineClass方法

native-lib.cpp中

extern "C" JNIEXPORT jint JNICALL redefineClass(JNIEnv *env, jclass clazz, jclass target, jbyteArray dex_bytes) {

ALOGI("==========redefineClass =======");

jvmtiClassDefinition def;

def.klass = target;

def.class_byte_count = static_cast(env->GetArrayLength(dex_bytes));

signed char *redef_bytes = env->GetByteArrayElements(dex_bytes, nullptr);

jvmtiError res = localJvmtiEnv->Allocate(def.class_byte_count,

const_cast(&def.class_bytes));

if (res != JVMTI_ERROR_NONE) {

return static_cast(res);

}

memcpy(const_cast(def.class_bytes), redef_bytes, def.class_byte_count);

env->ReleaseByteArrayElements(dex_bytes, redef_bytes, 0);

// Do the redefinition.

res = localJvmtiEnv->RedefineClasses(1, &def);

return static_cast(res);

}

3. 关于JVMTI的更多功能函数有空再探索(jvmti超级适合Android APM,赛高!!!)

代码中已实现 MethoddEntry,对方法调用的hook能打印函数调用栈,

实现了获取classLoader加载的所有类信息

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值