草庐IT

motion-tracking-jni-example

全部标签

java - 在 C (JNI) 中结束 Java 线程

亲爱的多线程/Java/C/JNI大师们,我有一个稍微具体的问题。我有一个生成线程的Java程序。在run()方法中,调用C(通过JNI),首先在TLS中分配线程局部变量,然后进入event_loop(因此线程的默认生命周期由该循环决定).我现在的问题是,如果出现类似SIGSEGV的情况,如何能够关闭/终止线程。重要的是整个进程和其中的其他线程可以继续。这就是我们使用TLS分离线程的原因。(我知道,有些人不鼓励这样做,当然做防御性编程是正确的,试图提前避免这种崩溃。这段代码仅供迁移期间使用,因为我们正在从C转换到Java.但由于我们拥有的资源很少,这将需要一些时间。)classMyTh

java - 为 JDK 10 中的类文件生成 JNI 头文件

Javanative接口(interface)(JNI)的一个组成部分是通过Cheader桥接JVM代码和native代码。过去生成这些头文件的方法非常简单:只需在类文件上调用命令行实用程序javah。然后,此过程将为任何标有native修饰符的方法生成原型(prototype)。然而,从Java10开始,javah实用程序hasbeenremoved,它的建议替换是javac的新标志“-h”。如果有可用的Java源文件,替换工作正常,但在只有编译的类文件可用的情况下就不够用了。(引发这个问题的问题是我试图从Scala源代码生成JNI绑定(bind)。我目前的方法是先编译它们,然后在生

Android Java代码与JNI交互 JNI方法Java类字段 (六)

🔥AndroidStudio版本🔥   🔥Java基础类型数据对应Native层的字母🔥 通过jni查找java某个类中相应字段对应的数据类型,需要使用到jni中的GetFieldID()函数jfieldIDGetFieldID(jclassclazz,constchar*name,constchar*sig){returnfunctions->GetFieldID(this,clazz,name,sig);}*|Java|JNI|*|boolean|Z|*|byte|B|*|char|C|*|short|S|*|int|I|*|long|J|*|float|F|*|double|D|🔥Jav

java - 为什么在 Joshua Bloch Effective Java Example 中双重检查锁定快 25%

下面是EffectiveJava第二版的一个片段。作者声称以下代码比不使用result变量的代码快25%。根据这本书“这个变量的作用是确保该字段在已经初始化的常见情况下只被读取一次。”.我无法理解为什么与不使用局部变量result相比,初始化值后这段代码会更快。在任何一种情况下,无论您是否使用局部变量result,您在初始化后都将只有一次volatile读取。//Double-checkidiomforlazyinitializationofinstancefieldsprivatevolatileFieldTypefield;FieldTypegetField(){FieldType

java - Oracle 接手后,sun SCJP/SCJA/SCEA tracks 有哪些变化?

上下文:看起来简单的scjp->scja->....sun认证的轨道已经与其他oracle风格的认证合并了...作为开发人员,我最近花了一些时间试图找出新的认证的“途径”。现有资源:这里有一个非常密集但信息丰富的页面:http://en.wikipedia.org/wiki/Sun_Certified_Professional当然,Oracle网站上也充满了不同认证事实的链接和图表。我的问题:不清楚是否出现了新的java认证范例或途径,因此旧的SCJP风格认证是否仍然存在(尽管名称不同),也不清楚整个认证是什么管道看起来像:例如,这张图(来自旧的sun认证)http://www.whi

java - 通过jni将jint数组从c返回到java

我在java中创建了一个整数数组,并通过jni将数组传递给cpp程序我的代码是:importjava.util.*;classSendArray{//Nativemethoddeclarationnativeint[]loadFile(int[]name);//Loadthelibrarystatic{System.loadLibrary("nativelib");}publicstaticvoidmain(Stringargs[]){intarr[]={1,2,3,4,5,6,7,8,9,10};//CreateclassinstanceSendArraymappedFile=new

java - 从 JNI/NDK 将二维原始数组从 C 返回到 Java

我找到了大量关于如何在JNI中生成二维基元数组并将其返回给Java的文档。但是这些信息无法描述如何在C中给定上下文传递一个已经存在的2Dfloat组(float**)。为了明确描述我的问题,我将添加一些我想要实现的C伪代码://Returnsa2DfloatarrayfromCtoJavajfloatArrayndk_test_getMy2DArray(JNIEnv*env,jobjectthiz,jlongcontext){//CastmycontextreferenceMyContextRefcontextRef=(MyContextRef)context;//Incasewene

java - 如何确定 JNI 全局引用内存泄漏的原因?

我正在使用Tomcat,在停止我的Web应用程序后,仍然存在对我的Web应用程序的类加载器实例的引用。结果是大量内存(主要与静态数据相关)不会被释放。这迟早会导致OutOfMemoryError。我做了一个heapdump,然后我意识到它由一个JNIglobalreference持有防止类加载器将是garbagecollected.我的应用程序不使用JNI。我也没有使用ApacheTomcatNativeLibrary。我正在使用Sun/OracleJDK。我想追查这个全局引用的原因/来源。(我的猜测是JVM内部引用了类加载器-但为什么/在哪里?)。问题:有哪些方法/工具集可以实现这一

java - 使用相对路径名从不同目录加载 JNI 库的可移植语句?

是否有独立于平台的Java语句从不同于Java源代码所在的目录加载native库?我想使用这样的东西:publicclassHelloWorld{static{System.loadLibrary("../some_project/HelloWorld");}publicstaticnativevoidprint();}问题是System.loadLibrary()不支持路径名参数中的目录分隔符。另外,不幸的是,System.load()需要一个绝对路径名,这不仅意味着我不能像上面那样指定一个相对目录(我想这样做),而且还需要参数包含,例如,前面的Linux系统上JNI库名称的“lib

java - Eclipse:无法加载 JNI 共享库“C:\Program Files(x86)\Java\jdk1.7.0_15\bin\..\jre\bin\client\jvm.dll

我正在尝试安装Eclipse。为了安装,我已经完成了以下操作。在C:​​\ProgramFiles(x86)\Java\JDK1.7.0_15安装JDK7u1564位(实际下载名称:jdk-7u15-windows-i586.exe)我在管理员中运行cmd并键入“C:\Users\Alfred>java-version”,这给了我“Java版本“1.7.0_15”java(TM)SE运行时环境(build1.7.0_15-b03)JavaHotspot(TM)ClientVM(build23.7-b01,混合模式,共享)在同一个cmd窗口中,我输入了“C:\Users\Alfred>j