有一点示范代码,不过代码内容有点敏感,所以我换成网上找的一段代码来进行调试。
源码来自:detect_bt_arm
在android jni中
void *thread2(void *) __attribute__ ((noreturn));
void thread1(void) __attribute__ ((noreturn));
uint32_t global_value = 0;
#define PRINT "value: 0x%x\n"
void *thread2(void *data) {
for (;;) {
sleep(1);
__android_log_print(ANDROID_LOG_ERROR, "detect", PRINT, global_value);
}
}
void thread1(void) {
for (;;) {
sleep(5);
__asm__ __volatile__ ("mov r0, %[global];"
"mov r1, #1;"
"add r1, r1, #1;" "str r1, [r0];"
"add r1, r1, #1;" "str r1, [r0];"
"add r1, r1, #1;" "str r1, [r0];"
"add r1, r1, #1;" "str r1, [r0];"
"add r1, r1, #1;" "str r1, [r0];"
"add r1, r1, #1;" "str r1, [r0];"
"add r1, r1, #1;" "str r1, [r0];"
"add r1, r1, #1;" "str r1, [r0];"
"add r1, r1, #1;" "str r1, [r0];"
"add r1, r1, #1;" "str r1, [r0];"
"add r1, r1, #1;" "str r1, [r0];"
"add r1, r1, #1;" "str r1, [r0];"
"add r1, r1, #1;" "str r1, [r0];"
"add r1, r1, #1;" "str r1, [r0];"
"add r1, r1, #1;" "str r1, [r0];"
"add r1, r1, #1;" "str r1, [r0];"
"add r1, r1, #1;" "str r1, [r0];"
"add r1, r1, #1;" "str r1, [r0];"
"add r1, r1, #1;" "str r1, [r0];"
"add r1, r1, #1;" "str r1, [r0];"
"add r1, r1, #1;" "str r1, [r0];"
"add r1, r1, #1;" "str r1, [r0];"
"add r1, r1, #1;" "str r1, [r0];"
"add r1, r1, #1;" "str r1, [r0];"
"add r1, r1, #1;" "str r1, [r0];"
"add r1, r1, #1;" "str r1, [r0];"
"add r1, r1, #1;" "str r1, [r0];"
"add r1, r1, #1;" "str r1, [r0];"
"add r1, r1, #1;" "str r1, [r0];"
"add r1, r1, #1;" "str r1, [r0];"
"add r1, r1, #1;" "str r1, [r0];"
:
:[global] "r"(&global_value)
:
);
}
}
extern "C"
JNIEXPORT jstring JNICALL
Java_xd_magic_os_until_BaseActivity_detectedBTArm(
JNIEnv *env,
jobject /* this */) {
std::string message = "";
pthread_t thread_data2;
int status;
status = pthread_create(&thread_data2, NULL, thread2, NULL);
if (status)
perror("pthread_create()");
thread1();
return env->NewStringUTF(message.c_str());
}
下面是一点方法:
android中打印日志的方法是:
#include <android/log.h>
__android_log_write(ANDROID_LOG_ERROR, "yeshen", "start 1");
__android_log_print(ANDROID_LOG_ERROR, "yeshen", "out=%d\n", a);
编译出so库之后看so的信息
file libnative-lib.so
libnative-lib.so: ELF 32-bit LSB shared object, ARM, EABI5 version 1 (SYSV), dynamically linked, BuildID[sha1]=392a53add6c490e6dc848cead3391b0a96802c68, not stripped
从so库看汇编代码
objDump -d libnative-lib.so > 1.txt
vim 1.txt
当然首先要先懂汇编的代码是要干嘛。
完
本文介绍了一个使用 Android JNI 实现的多线程示例,包括 C 语言编写的线程函数和 Java 调用接口。通过示例展示了如何在 Android 中创建和管理本地线程,并在后台循环打印全局变量。
1474

被折叠的 条评论
为什么被折叠?



