android nativate 动态注册 静态注册
说明:在java函数的入口比较容易分析,
把activity的生命周期或者关键函数通过放在so层,分析起来就困难多了
1、在MainActivity中
package com.demo.nativate; import androidx.appcompat.app.AppCompatActivity; import android.os.Bundle;
import android.widget.TextView; import com.demo.nativate.databinding.ActivityMainBinding; public class MainActivity extends AppCompatActivity { // Used to load the 'nativate' library on application startup.
static {
System.loadLibrary("nativate");
} private ActivityMainBinding binding; // @Override
protected native void onCreate(Bundle savedInstanceState);
// {
// super.onCreate(savedInstanceState);
// setContentView(R.layout.activity_main);
// // Example of a call to a native method
// TextView tv = findViewById(R.id.sample_text);
// tv.setText(stringFromJNI());
// } /**
* A native method that is implemented by the 'nativate' native library,
* which is packaged with this application.
*/
public native String stringFromJNI();
}
2、静态注册
#include <jni.h>
#include <string>
#include <android/log.h> #define LOGD(...) __android_log_print(ANDROID_LOG_DEBUG, "Tag->", __VA_ARGS__) extern "C" JNIEXPORT jstring JNICALL
Java_com_demo_nativate_MainActivity_stringFromJNI(
JNIEnv *env,
jobject /* this */) {
std::string hello = "Hello from C++";
return env->NewStringUTF(hello.c_str());
}
extern "C"
JNIEXPORT void JNICALL
Java_com_demo_nativate_MainActivity_onCreate(JNIEnv *env, jobject thiz,
jobject saved_instance_state) {
// TODO: implement onCreate()
LOGD("静态注册 MainActivity OnCreate be called!");
//super.onCreate(savedInstanceState);
jclass MainActivityClass = env->GetObjectClass(thiz);
jclass AppCompatActivityClass = env->GetSuperclass(MainActivityClass);
jmethodID onCreate = env->GetMethodID(AppCompatActivityClass, "onCreate",
"(Landroid/os/Bundle;)V");
env->CallNonvirtualVoidMethod(thiz, AppCompatActivityClass, onCreate,
saved_instance_state); //调用父类方法
LOGD("静态注册 super.onCreate(savedInstanceState) be called!");
// setContentView(R.layout.activity_main);
jmethodID setContentView_id = env->GetMethodID(MainActivityClass, "setContentView", "(I)V");
jclass layoutClass = env->FindClass("com/demo/nativate/R$layout");
jfieldID activity_main_id = env->GetStaticFieldID(layoutClass, "activity_main", "I");
jint id_txt_main = env->GetStaticIntField(layoutClass, activity_main_id);
env->CallVoidMethod(thiz, setContentView_id, id_txt_main);
LOGD("静态注册 setContentView(R.layout.activity_main); be called!");
// TextView tv = findViewById(R.id.sample_textFId);
jmethodID findViewById_mid = env->GetMethodID(MainActivityClass, "findViewById",
"(I)Landroid/view/View;");
jclass RIdClass = env->FindClass("com/demo/nativate/R$id");
jfieldID sample_textFId = env->GetStaticFieldID(RIdClass, "sample_text", "I");
jint sample_textF = env->GetStaticIntField(RIdClass, sample_textFId);
LOGD("静态注册 TextView tv = findViewById(R.id.sample_textFId); be called!");
jobject tvobject = env->CallObjectMethod(thiz, findViewById_mid, sample_textF);
// tv.setText(stringFromJNI());
jclass tvClass = env->GetObjectClass(tvobject);
jmethodID setText_mid = env->GetMethodID(tvClass, "setText", "(Ljava/lang/CharSequence;)V");
jstring text = env->NewStringUTF("onCreate-->Native success by c++ !!!");
env->CallVoidMethod(tvClass, setText_mid, text);
env->DeleteLocalRef(text);
LOGD("静态注册 tv.setText(stringFromJNI());; be called!");
}
3、动态注册
#include <jni.h>
#include <string>
#include <android/log.h> #define LOGD(...) __android_log_print(ANDROID_LOG_DEBUG, "Tag->", __VA_ARGS__) extern "C" JNIEXPORT jstring JNICALL
Java_com_demo_nativate_MainActivity_stringFromJNI(
JNIEnv *env,
jobject /* this */) {
std::string hello = "Hello from C++";
return env->NewStringUTF(hello.c_str());
}
extern "C"
JNIEXPORT void JNICALL
Java_com_demo_nativate_MainActivity_onCreate(JNIEnv *env, jobject thiz,
jobject saved_instance_state) {
// TODO: implement onCreate()
LOGD("静态注册 MainActivity OnCreate be called!");
//super.onCreate(savedInstanceState);
jclass MainActivityClass = env->GetObjectClass(thiz);
jclass AppCompatActivityClass = env->GetSuperclass(MainActivityClass);
jmethodID onCreate = env->GetMethodID(AppCompatActivityClass, "onCreate",
"(Landroid/os/Bundle;)V");
env->CallNonvirtualVoidMethod(thiz, AppCompatActivityClass, onCreate,
saved_instance_state); //调用父类方法
LOGD("静态注册 super.onCreate(savedInstanceState) be called!");
// setContentView(R.layout.activity_main);
jmethodID setContentView_id = env->GetMethodID(MainActivityClass, "setContentView", "(I)V");
jclass layoutClass = env->FindClass("com/demo/nativate/R$layout");
jfieldID activity_main_id = env->GetStaticFieldID(layoutClass, "activity_main", "I");
jint id_txt_main = env->GetStaticIntField(layoutClass, activity_main_id);
env->CallVoidMethod(thiz, setContentView_id, id_txt_main);
LOGD("静态注册 setContentView(R.layout.activity_main); be called!");
// TextView tv = findViewById(R.id.sample_textFId);
jmethodID findViewById_mid = env->GetMethodID(MainActivityClass, "findViewById",
"(I)Landroid/view/View;");
jclass RIdClass = env->FindClass("com/demo/nativate/R$id");
jfieldID sample_textFId = env->GetStaticFieldID(RIdClass, "sample_text", "I");
jint sample_textF = env->GetStaticIntField(RIdClass, sample_textFId);
LOGD("静态注册 TextView tv = findViewById(R.id.sample_textFId); be called!");
jobject tvobject = env->CallObjectMethod(thiz, findViewById_mid, sample_textF);
// tv.setText(stringFromJNI());
jclass tvClass = env->GetObjectClass(tvobject);
jmethodID setText_mid = env->GetMethodID(tvClass, "setText", "(Ljava/lang/CharSequence;)V");
jstring text = env->NewStringUTF("onCreate-->Native success by c++ !!!");
env->CallVoidMethod(tvClass, setText_mid, text);
env->DeleteLocalRef(text);
LOGD("静态注册 tv.setText(stringFromJNI());; be called!");
} void dynamicRegister(JNIEnv *env, jobject thiz, jobject saved_instance_state) {
LOGD("动态注册 MainActivity OnCreate be called!");
//super.onCreate(savedInstanceState);
jclass MainActivityClass = env->GetObjectClass(thiz);
jclass AppCompatActivityClass = env->GetSuperclass(MainActivityClass);
jmethodID onCreate = env->GetMethodID(AppCompatActivityClass, "onCreate",
"(Landroid/os/Bundle;)V");
env->CallNonvirtualVoidMethod(thiz, AppCompatActivityClass, onCreate,
saved_instance_state); //调用父类方法
LOGD("动态注册 super.onCreate(savedInstanceState) be called!");
// setContentView(R.layout.activity_main);
jmethodID setContentView_id = env->GetMethodID(MainActivityClass, "setContentView", "(I)V");
jclass layoutClass = env->FindClass("com/demo/nativate/R$layout");
jfieldID activity_main_id = env->GetStaticFieldID(layoutClass, "activity_main", "I");
jint id_txt_main = env->GetStaticIntField(layoutClass, activity_main_id);
env->CallVoidMethod(thiz, setContentView_id, id_txt_main);
LOGD("动态注册 setContentView(R.layout.activity_main); be called!");
// TextView tv = findViewById(R.id.sample_textFId);
jmethodID findViewById_mid = env->GetMethodID(MainActivityClass, "findViewById",
"(I)Landroid/view/View;");
jclass RIdClass = env->FindClass("com/demo/nativate/R$id");
jfieldID sample_textFId = env->GetStaticFieldID(RIdClass, "sample_text", "I");
jint sample_textF = env->GetStaticIntField(RIdClass, sample_textFId);
LOGD("动态注册 TextView tv = findViewById(R.id.sample_textFId); be called!");
jobject tvobject = env->CallObjectMethod(thiz, findViewById_mid, sample_textF);
// tv.setText(stringFromJNI());
jclass tvClass = env->GetObjectClass(tvobject);
jmethodID setText_mid = env->GetMethodID(tvClass, "setText", "(Ljava/lang/CharSequence;)V");
jstring text = env->NewStringUTF("onCreate-->Native success by c++ !!!");
env->CallVoidMethod(tvClass, setText_mid, text);
env->DeleteLocalRef(text);
LOGD("动态注册 tv.setText(stringFromJNI());; be called!"); } static int registerNativates(JNIEnv *env) {
jclass mainActivityClass = env->FindClass("com/demo/nativate/MainActivity");
if (mainActivityClass == nullptr) {
return JNI_FALSE;
}
JNINativeMethod methods[] = {
{"onCreate", "(Landroid/os/Bundle;)V", (void *) dynamicRegister}
};
int methodsNum = sizeof(methods) / sizeof(methods[0]);
if (env->RegisterNatives(mainActivityClass, methods, methodsNum) < 0) {
return JNI_FALSE;
}
return JNI_TRUE;
} jint JNI_OnLoad(JavaVM *vm, void *reserved) {
LOGD("调用的 JNI_Onload函数");
//获得JNI环境
JNIEnv *env = nullptr;
if ((vm->GetEnv(reinterpret_cast<void **>(&env), JNI_VERSION_1_6)) != JNI_OK) {
return -1;
} else {
if (!registerNativates(env)) {
return -1;
}
}
return JNI_VERSION_1_6;
}
4、小结
当动静态注册同时存在时,会使用动态注册。
在android studio中,代码会出现红色的显示,不用担心是正常现象。
android nativate 动态注册 静态注册的更多相关文章
- Android中的BroadCast静态注册与动态注册
1.静态注册 新建MyBroadcast类继承BroadcastReceiver,实现onReceive方法 /** * Author:JsonLu * DateTime:2015/9/21 16:4 ...
- BroadcastReceiver(广播)的静态注册和动态注册 --Android开发
BroadcastReceiver是安卓四大组件之一,本例通过代码的方式演示静态注册和动态注册. 1.静态注册 静态注册只需要AndroidManifest.xml中进行配置: AndroidMani ...
- Oracle监听静态注册和动态注册
静态注册和动态注册总结 一.什么是注册? 注册就是将数据库作为一个服务注册到监听程序.客户端不需要知道数据库名和实例名,只需要知道该数据库对外提供的服务名就可以申请连接到数据库.这个服务名可能与实例名 ...
- Oracle监听器—静态注册
注册就是将数据库作为一个服务注册到监听程序.客户端不需要知道数据库名和实例名,只需要知道该数据库对外提供的服务名就可以申请连接到数据库.这个服务名可能与实例名一样,也有可能不一样. 注册分: 1. 静 ...
- BroadcastReceiver的两种注册方式之------静态注册
activity_main.xml <LinearLayout xmlns:android="http://schemas.android.com/apk/res/android&qu ...
- Android开发4: Notification编程基础、Broadcast的使用及其静态注册、动态注册方式
前言 啦啦啦~(博主每次开篇都要卖个萌,大家是不是都厌倦了呢~) 本篇博文希望帮助大家掌握 Broadcast 编程基础,实现动态注册 Broadcast 和静态注册 Broadcast 的方式以及学 ...
- Android(java)学习笔记173:BroadcastReceiver之 静态注册 和 动态注册
1. 广播接受者>什么是广播.收音机.电台:对外发送信号.收音机:接收电台的信号. >在android系统里面,系统有很多重要的事件: 电池电量低,插入充电器,sd卡被移除,有电话打出去, ...
- Android(java)学习笔记116:BroadcastReceiver之 静态注册 和 动态注册
1. 广播接受者>什么是广播.收音机.电台:对外发送信号.收音机:接收电台的信号. >在android系统里面,系统有很多重要的事件: 电池电量低,插入充电器,sd卡被移除,有电话打出去, ...
- Android只能动态注册的广播Action
只能动态注册的广播(部分): android.intent.action.SCREEN_ON android.intent.action.SCREEN_OFF android.intent.actio ...
- Android实现AppWidget、Broadcast静态注册
Android实现AppWidget.Broadcast静态注册 本篇博客是基于我上一篇博客继续修改的,详情请看Android实现AppWidget.Broadcast动态注册 开发工具:Andori ...
随机推荐
- 内网横向渗透 之 ATT&CK系列一 之 信息收集
前言 靶机下载地址:ATT&CK 拓扑图: 通过模拟真实环境搭建的漏洞靶场,完全模拟ATK&CK攻击链路进行搭建,形成完整个闭环.虚拟机默认密码为hongrisec@2019. 环境搭 ...
- liunx的三个时间atime,mtime,ctime详细说明与使用场景
导航:一.文件与文件夹三个时间:atime,mtime,ctime的含义二.ll命令查看文件时间三.stat命令查看文件的时间四.测试创建/修改文件的时间五.常用命令关于文件时间相关 - - - - ...
- 手把手教你使用LabVIEW OpenCV dnn实现物体识别(Object Detection)含源码
前言 今天和大家一起分享如何使用LabVIEW调用pb模型实现物体识别,本博客中使用的智能工具包可到主页置顶博客LabVIEW AI视觉工具包(非NI Vision)下载与安装教程中下载 一.物体识别 ...
- tensorboard图表显示不全的问题
之前跑bcq生成tensorboard文件的时候,有二十个点用来描图,然而后10个数据点总是不显示,之后将tensorboard换成tensorboardX便解决了问题. 比如 from torch. ...
- 去除router-link中的下划线
文章目录 1.设置router-link的样式 2.效果展示 1.设置router-link的样式 text-decoration: none; 2.效果展示
- Hadoop集群简单入门
Hadoop集群搭建 自己配置Hadoop的话太过复杂了,因为自己着急学习,就使用了黑马的快照.如果小伙伴们也想的话可以直接看黑马的课程,快照的话关注黑马程序员公众号,输入Hadoop就能获取资料,到 ...
- k8s集权IP更换
-.背景描述 背景:在场内进行部署完成后标准版产品,打包服务器到客户现场后服务不能正常使用,因为客户现场的IP地址不能再使用场内的IP,导致部署完的产品环境在客户现场无法使用:此方案就是针对这一问题撰 ...
- scrapy出现SSL问题 如何解决? <twisted.python.failure.Failure OpenSSL.SSL.Error: [('SSL routines', '', 'unsafe legacy renegotiation disabled')]>
问题:<twisted.python.failure.Failure OpenSSL.SSL.Error: [('SSL routines', '', 'unsafe legacy renego ...
- 第一百零六篇:变量的不同声明(var,let和const的不同)
好家伙,JS基础接着学, 本篇内容为<JS高级程序设计>第三章学习笔记 1.变量 ECMAScript 变量是松散类型的,意思是变量可以用于保存任何类型的数据. (确实松散,不像C或C++ ...
- python(27)反射机制
1. 什么是反射? 它的核心本质其实就是基于字符串的事件驱动,通过字符串的形式去操作对象的属性或者方法 2. 反射的优点 一个概念被提出来,就是要明白它的优点有哪些,这样我们才能知道为什么要使用反射. ...