- iOS/Objective-C 元类和类别
- objective-c - -1001 错误,当 NSURLSession 通过 httpproxy 和/etc/hosts
- java - 使用网络类获取 url 地址
- ios - 推送通知中不播放声音
我正在尝试创建一个新线程,因此我将 VM 从我的方法初始化(从 Java 调用)传递到我的新线程。在线程中,我调用 AttachCurrentThread 并获取 JNIEnv* env。
稍后,我尝试使用环境调用 GetObjectClass,但它崩溃了。我相信这是因为对象可能未初始化,但我正在尝试调用在包含 native 方法的类中定义的方法。我一直在尝试遵循 http://java.sun.com/docs/books/jni/html/fldmeth.html 的第 4.2 节(开头) .
非常奇怪的事情:我正在使用运行 2.2 的 HTC Dream 进行测试并且以下代码不会崩溃,但是使用运行 2.2.2 的摩托罗拉 Droid 时它会一直崩溃!
这是我的代码:
C++
JNIEXPORT void JNICALL Java_com_device_client_HostConnection_initialize
(JNIEnv * env, jobject obj, jint port) {
JavaVM *vm;
jint result = env->GetJavaVM(&vm);
if (result < 0) {
LOGE("Error using GetJavaVM\n");
exit(-1);
}
struct javaInfo* data = (struct javaInfo*) malloc(sizeof(struct javaInfo));
data->vm = vm;
data->javaObjHost = obj;
pthread_t pth;
pthread_create(&pth, NULL, startServer, (void *) data);
}
新线程:
void *startServer(void* arg) {
jclass cls;
jmethodID mid;
JNIEnv* env = NULL;
struct javaInfo* data = (struct javaInfo*) arg;
JavaVM* vm = data->vm;
jobject javaObjHost = data->javaObjHost;
if (vm == NULL) {
LOGE("VM is null\n");
}
vm->AttachCurrentThread(&env, NULL);
cls = env->GetObjectClass(javaObjHost);
mid = env->GetMethodID(cls, "setStatus", "(Z)V");
if (mid == 0) {
LOGD("ERROR: GetMethodID\n");
exit(-1);
}
env->CallVoidMethod(javaObjHost, mid, false);
行 cls = env->GetObjectClass(javaObjHost);正在崩溃并显示以下输出:
W/dalvikvm( 5827): JNI WARNING: 0x44872da0 is not a valid JNI reference
W/dalvikvm( 5827): in Ldalvik/system/NativeStart;.run ()V (GetObjectClass)
I/dalvikvm( 5827): "Thread-9" prio=5 tid=8 RUNNABLE
I/dalvikvm( 5827): | group="main" sCount=0 dsCount=0 s=N obj=0x448734c8 self=0x229da8
I/dalvikvm( 5827): | sysTid=5834 nice=0 sched=0/0 cgrp=default handle=2265136
I/dalvikvm( 5827): | schedstat=( 885010 3631591 2 )
I/dalvikvm( 5827): at dalvik.system.NativeStart.run(Native Method)
I/dalvikvm( 5827):
E/dalvikvm( 5827): VM aborting
I/DEBUG ( 5511): *** *** *** *** *** *** *** *** *** *** *** *** *** *** *** ***
I/DEBUG ( 5511): Build fingerprint: 'verizon/voles/sholes/sholes:2.2.2/FRG83G/91102:user/release-keys'
I/DEBUG ( 5511): pid: 5827, tid: 5834 >>> com.device.client <<<
I/DEBUG ( 5511): signal 11 (SIGSEGV), fault addr deadd00d
....
我的java代码:
public class HostConnection {
static {
System.loadLibrary("hostConnection");
}
public void setStatus(boolean bool) {
...
}
public native void initialize(int defaultPort);
}
谁能帮帮我?我想在我的类中调用 setStatus() 方法,而不创建新对象。
编辑:
这是新代码,目前正在崩溃。
JNIEXPORT void JNICALL Java_com_device_client_HostConnection_initialize
(JNIEnv * env, jobject obj, jint port) {
JavaVM *vm;
jint result = env->GetJavaVM(&vm);
if (result < 0) {
LOGE("Error using GetJavaVM\n");
exit(-1);
}
jclass clsLocal = env->GetObjectClass(obj);
if (clsLocal == NULL) {
LOGE("ERROR: Cannot find class HostConnection\n");
exit(-1);
}
jclass hostClass = (jclass) env->NewWeakGlobalRef(clsLocal);
if (hostClass == NULL) {
LOGE("ERROR: Run out of memory for weak global ref\n");
exit(-1);
}
struct javaInfo* data = (struct javaInfo*) malloc(sizeof(struct javaInfo));
data->vm = vm;
data->hostClass = hostClass;
pthread_t pth;
pthread_create(&pth, NULL, startServer, (void *) data);
}
void *startServer(void* arg) {
JNIEnv* env = NULL;
jmethodID mid;
struct fb_var_screeninfo vinfo;
char server[MAXHOSTNAMELEN];
struct javaInfo* data = (struct javaInfo*) arg;
JavaVM* vm = data->vm;
jclass hostClass = data->hostClass;
if (vm == NULL) {
LOGE("VM is null\n");
}
vm->AttachCurrentThread(&env, NULL);
mid = env->GetMethodID(hostClass, "setStatus", "(Z)V");
if (mid == 0) {
LOGD("ERROR: GetMethodID\n");
exit(-1);
}
env->CallVoidMethod(hostClass, mid, false);
}
我遇到以下崩溃:
W/dalvikvm( 7650): JNI WARNING: jclass points to invalid object 0xda88d23f
I/dalvikvm( 7650): "Thread-9" prio=5 tid=8 NATIVE
I/dalvikvm( 7650): | group="main" sCount=0 dsCount=0 s=N obj=0x448734f8 self=0x228a20
I/dalvikvm( 7650): | sysTid=7657 nice=0 sched=0/0 cgrp=default handle=2260192
I/dalvikvm( 7650): | schedstat=( 854493 9155273 2 )
I/dalvikvm( 7650): at dalvik.system.NativeStart.run(Native Method)
I/dalvikvm( 7650):
E/dalvikvm( 7650): VM aborting
I/DEBUG ( 5511): *** *** *** *** *** *** *** *** *** *** *** *** *** *** *** ***
I/DEBUG ( 5511): Build fingerprint: 'verizon/voles/sholes/sholes:2.2.2/FRG83G/91102:user/release-keys'
I/DEBUG ( 5511): pid: 7650, tid: 7657 >>> com.device.client <<<
I/DEBUG ( 5511): signal 11 (SIGSEGV), fault addr deadd00d
我知道它在 GetMethodID() 上崩溃。我真的不知道为什么。非常感谢任何帮助。
非常感谢。
最佳答案
您从Java_com_device_client_HostConnection_initialize
获取对象
作为本地引用,然后将其传递给javaInfo
结构中的新线程。
局部引用只在当前线程有效,与JNIEnv*
指针一样。
因此,当您从新线程中的结构中获取它时,您对该对象的引用无效,这就解释了崩溃。
尝试使用 JNIEnv
中的 NewWeakGlobalRef
方法在 Java_com_device_client_HostConnection_initialize
方法中获取 WeakGlobal 引用。
阅读 JNI 文档的第五章以了解本地、全局和弱全局引用之间的区别。
关于安卓 JNI : GetObjectClass crashes with SIGSEGV (not a valid JNI reference),我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/7864614/
我想在 java 中声明一个对象,就像在 C++ 中指向指针的指针,让我给你看一个例子: //*** At the application startup //Initialize a setting
考虑这段代码, struct A {}; struct B { B(const A&) {} }; void f(B) { cout << "f()"<
我正在尝试将一个C程序翻译成Rust。。C程序具有以下结构(归结为MRE):。在一个函数中,我将执行以下指针魔术:。不,我的问题是:我将如何在铁锈中实现同样的目标?。到目前为止,我在《铁锈》中尝试过的
我目前正在尝试将一个C程序翻译成Rust。。C程序具有以下结构(归结为MRE):。在一个函数中,我将执行以下指针魔术:。不,我的问题是:我将如何在铁锈中实现同样的目标?。到目前为止,我在《铁锈》中尝试
这个问题在这里已经有了答案: Add managed DLL dependencied to unmanaged C++ project (1 个回答) 关闭 6 年前。 我有这样一个场景: 使用
这是一个常见问答的集合,这也是一个社区维基,所以每个人都被邀请参与维护它。。正则表达式正在遭受给我ZE代码类型的问题和没有解释的糟糕答案。此参考旨在提供指向质量问答的链接。。此参考适用于以下语言:PH
我正在尝试在方案中模拟堆栈。我正在使用 DrScheme 并选择语言 R5RS。我需要创建 pop、push 和 peek 的函数。但我无法弄清楚如何通过引用传递。我已经阅读了一些关于盒子的信息,但是
我陷入了这个错误。我将代码部署在生产服务器上,它在端口 80 上运行。当我尝试登录管理页面时。如图所示,它给了我 403 错误。 可能是什么原因?我的 Django 代码或 nginx 配置有问题吗?
这是一段简单的 C++ 代码: A foo(){ A a; // create a local A object return a; } void bar(const A & a_r){ }
我正在使用从 torrenteditor 获取的 php 脚本来创建 torrent 文件,但是当我使用指定的方法创建新的 torrent 文件时,torrent 文件被创建但我收到很多通知。,就像这
MySQL: REFERENCES vs FOREIGN KEY + REFERENCES 我认为 REFERENCES 是更冗长的 FOREIGN KEY REFERENCES 语法的某种速记语法。
我想使用基于另一个方法引用的方法引用。这有点难以解释,所以我给你举个例子: Person.java public class Person{ Person sibling; int a
Java/C# 语言律师喜欢说他们的语言通过值传递引用。这意味着“引用”是在调用函数时复制的对象指针。 同时,在 C++ 中(以及在 Perl 和 PHP 中更动态的形式),引用是某个其他名称(或动态
当我需要实现递归 lambda 时,通常我这样做: auto factorial = [](auto& self, int n) -> int { return n == 0 ? 1 : n
我目前正在研究 DDD ,需要一些启发。 我有两个实体 Temple TempleVariant Temple(听筒)包含基本信息(名称,描述等),并具有n个变体,它们具有技术描述(CAD绘图,尺寸,
在 Grails 中 belongsTo允许一个域类与另一个域类建立级联关系。使用belongsTo时有两种类型的关系:引用和无引用。 Reference 在拥有的对象上创建属性,而 No Refer
我正在使用 AWS 和 Django Rest Framework 开发 Web 应用程序。(Django:v1.8,DRF:v3) 我一直在为 POST 多部分表单请求获取 django.reque
我按照下面的定义公开了 WCF 端点, 当我在 .NET 3.5 中添加“服务引用”时,我们在代理中获得了以下类,这非常好: [Syst
我在玩 constexpr 引用时产生了这种感觉。但问题本身与 constexpr 无关,只是被它揭示。 我们知道有“指向const的指针”,也有“const指针”。顺便说一句,由于后者的使用比前者少
我有 2 种类型的 refences,它们中的每一种都可以正常工作。 我尝试使用每一个并在 project build 中得到相同的结果。 请向我解释 COM 引用和引用之间的区别。 谢谢你。 最佳答
我是一名优秀的程序员,十分优秀!