- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我有下面的代码,我想调用在同一个源文件中实现的函数,在本例中使用 C 语言:
JNIEXPORT jstring JNICALL MyClass_get_1Uname__C (JNIEnv *env, jclass class, jchar mode) {
return (*env)->NewStringUTF(env, "UsingStringC.get_Uname With Parameter");
}
JNIEXPORT jstring JNICALL MyClass_get_1Uname__ (JNIEnv *env, jclass class) {
printf("Attended by:get_1Uname__\nPassing to:get_1Uname__C\n");
return MyClass_get_1Uname__C(env,class,'a');
}
问题不在 Java 端:
public MyClass() {
System.out.println("testBefore");
String S2 = this.get_Uname('s');
System.out.println(S2);
System.out.println("testAfter"); // Work!!!
String S3 = this.get_Uname(); // Access Violation!!!
System.out.println(S3);
System.out.println("testFinish");
}
native public static String get_Uname(char mode);
native public static String get_Uname();
static {
try {
System.loadLibrary("UsingStringC");
} catch (java.lang.UnsatisfiedLinkError ex){
System.out.println("ERROR MESSAGE:"+ex.getMessage());
}
}
我有结果:
testBefore
UsingStringC.get_Uname With Parameter
testAfter
#
# A fatal error has been detected by the Java Runtime Environment:
#
# EXCEPTION_ACCESS_VIOLATION (0xc0000005) at pc=0x610e9914, pid=4712, tid=8668
#
# JRE version: Java(TM) SE Runtime Environment (8.0_20-b26) (build 1.8.0_20-b26)
# Java VM: Java HotSpot(TM) Client VM (25.20-b23 mixed mode windows-x86 )
# Problematic frame:
# C [cygwin1.dll+0xe9914]
#
# Failed to write core dump. Minidumps are not enabled by default on client versions of Windows
#
# An error report file with more information is saved as:
# D:\Developer\...\hs_err_pid4712.log
#
# If you would like to submit a bug report, please visit:
# http://bugreport.sun.com/bugreport/crash.jsp
# The crash happened outside the Java Virtual Machine in native code.
# See problematic frame for where to report the bug.
#
Java Result: 1
BUILD SUCCESSFUL (total time: 6 seconds)
我不知道如何在同一个源文件中调用一个包含的(声明的)函数...
如何执行?
.h 文件(头文件)
/*
* Class: MyClass
* Method: get_Uname
* Signature: (C)Ljava/lang/String;
*/
JNIEXPORT jstring JNICALL Java_MyClass_get_1Uname__C (JNIEnv *, jclass, jchar);
/*
* Class: MyClass
* Method: get_Uname
* Signature: ()Ljava/lang/String;
*/
JNIEXPORT jstring JNICALL Java_MyClass_get_1Uname__ (JNIEnv *, jclass);
int add(int , int);
int dif(int , int);
.c 文件(来源)
JNIEXPORT jstring JNICALL Java_MyClass_get_1Uname__C (JNIEnv *env, jclass class, jchar mode) {
if (mode == 'a' || mode == 'A' ) {
printf( "Addition %i\n", add(15, 10));
} else {
printf( "Difference %i\n", dif(15, 10));
}
return (*env)->NewStringUTF(env, "UsingStringC.get_Uname With Parameter");
}
JNIEXPORT jstring JNICALL Java_MyClass_get_1Uname__ (JNIEnv *env, jclass class) {
printf("Attended by:get_1Uname__\nPassing to:get_1Uname__C\n");
return Java_MyClass_get_1Uname__C(env,class,'a');
}
int add(int a, int b) {
int c = (a+b);
printf("Adding\n");
return c;
}
int dif(int a, int b) {
int c = (a-b);
printf("Differing\n");
return c;
}
Java 代码
public MyClass() {
System.out.println("testBefore"); // Work!!!
String S2 = this.get_Uname('s'); // Access Violation!!!
System.out.println(S2);
System.out.println("testAfter");
String S3 = this.get_Uname();
System.out.println(S3);
System.out.println("testFinish");
}
native public static String get_Uname(char mode);
native public static String get_Uname();
static {
try {
System.loadLibrary("UsingStringC");
} catch (java.lang.UnsatisfiedLinkError ex){
System.out.println("ERROR MESSAGE:"+ex.getMessage());
}
}
最佳答案
在 OS X 上,只要稍微清理一下代码,就完全没有问题:
H代码:
#include "jni.h"
/*
* Class: MyClass
* Method: get_Uname
* Signature: (C)Ljava/lang/String;
*/
JNIEXPORT jstring JNICALL Java_MyClass_get_1Uname__C (JNIEnv *, jclass, jchar);
/*
* Class: MyClass
* Method: get_Uname
* Signature: ()Ljava/lang/String;
*/
JNIEXPORT jstring JNICALL Java_MyClass_get_1Uname__ (JNIEnv *, jclass);
int add(int , int);
int dif(int , int);
C 代码:
#include "jni.h"
JNIEXPORT jstring JNICALL Java_MyClass_get_1Uname__C (JNIEnv *env, jclass class, jchar mode) {
if (mode == 'a' || mode == 'A' ) {
printf( "Addition %i\n", add(15, 10));
} else {
printf( "Difference %i\n", dif(15, 10));
}
return (*env)->NewStringUTF(env, "UsingStringC.get_Uname With Parameter");
}
JNIEXPORT jstring JNICALL Java_MyClass_get_1Uname__ (JNIEnv *env, jclass class) {
printf("Attended by:get_1Uname__\nPassing to:get_1Uname__C\n");
return Java_MyClass_get_1Uname__C(env,class,'a');
}
int add(int a, int b) {
int c = (a+b);
printf("Adding\n");
return c;
}
int dif(int a, int b) {
int c = (a-b);
printf("Differing\n");
return c;
}
Java代码:
public class MyClass {
public static void main(String [] arg) {
MyClass cls = new MyClass();
cls.test();
}
public void test() {
System.out.println("testBefore"); // Works!!!
String S2 = this.get_Uname('s'); // Works
System.out.println(S2);
System.out.println("testAfter");
String S3 = this.get_Uname(); // Works
System.out.println(S3);
System.out.println("testFinish");
}
native public static String get_Uname(char mode);
native public static String get_Uname();
static {
try {
System.loadLibrary("Simple");
} catch (java.lang.UnsatisfiedLinkError ex){
System.out.println("ERROR MESSAGE:"+ex.getMessage());
}
}
}
C 编译:
cc -g -shared -fpic -I${JAVA_HOME}/include \
-I${JAVA_HOME}/include/darwin simple.c \
-o libSimple.dylib
Java 编译:
javac MyClass.java
执行:
export LD_LIBRARY_PATH=.:$LD_LIBRARY_PATH
java MyClass
输出:
testBefore
Differing
Difference 5
UsingStringC.get_Uname With Parameter
testAfter
Attended by:get_1Uname__
Passing to:get_1Uname__C
Adding
Addition 25
UsingStringC.get_Uname With Parameter
testFinish
C 编译和库生成的设置是什么?你的 lib 位置在哪里?
关于java - JNI 从同一源 C 文件、Java 调用函数 JNI,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/31769750/
我刚开始使用 JNI,但遇到以下问题。 我有一个包含简单类的 C++ 库。我从 Java Android 项目中调用了三个 JNI 方法,分别实例化所述类、调用实例化类的方法并销毁它。我保留了对该对象
背景 我有一个 android 项目,它使用 JNI(使用 NDK)以 Java 和 C/C++ 进行编码。 我在java端创建了一个Jni java包装器,它将自己完成所有Jni操作,而除了这个包装
我想传递一个java对象的地址,JNI方法应该填充所传递对象的字段。1. java代码传递给定的对象引用。 JNI 方法应该能够缓存这个对象。这是一次性通话。2. 然后,java 对象使用不同的参数重
我本质上是在尝试遵循描述的 SO 解决方案 here , 但我遇到了问题。 这基本上就是我在 JNI 库中所做的事情: handle = dlopen("/data/data/lib/my.packa
我试图实现某种异常处理 一开始我打电话 jni::ExceptionDescribe() 之后我使用了的实现 How to obtain a description of a Java excepti
是否可以从不同 jni 库的另一个方法调用 1 个库的 jni 方法?例如:我有 2 个库 lib_1.so 和 lib_2.so。 我想从 lib_2.so 调用 lib_1.so 的方法 get_
我想在native方法中使用动态注册,所以我需要设置JNI_onLoad功能。我只是写了一个函数来获取两个数字的总和。但是,它无法正确构建。我该如何更正错误? 这是我的 *.cpp 文件,我将此文件命
我已经为 C 头文件制作了一个 make 文件,它工作正常,但是说 JNICALL 和 JNIEnv 存在语法错误,但我已经弄明白了这是因为头文件中的类型。 Image of the failure
我需要实现一个本地方法,比方说“public native void someFunc();”。我有两个库,libabc.so 和 libdef.so。 Java 使用 System.loadLibr
背景 我正在 eclipse 中为 android 开发一个应用程序,现在我遇到了一个问题,我需要你的帮助。所以我必须从 JAVA 应用程序调用用 C 编写的函数。但是在我编写代码的过程中,我有一些问
我正在使用 Android 上的 Java native 接口(interface)将当前 Activity 传递给 native 方法。但我没有使用类似 JNI 的函数名称来执行此操作。我正在手动注
我正在使用 JNI,我想知道是否可以通过 delegate 进行通信。 例如: Kotlin typealias MessageReceived = (msg: String) -> Unit ext
看来我对 JNI 的运气并不好。我正在等待我买的书到货,但现在是试错法。 我正在使用 JNI 来实现 Lua 求值器。 evaluatorNew() 只是创建一个新的 Evaluator() 对象,创
我有下面的代码,我想调用在同一个源文件中实现的函数,在本例中使用 C 语言: JNIEXPORT jstring JNICALL MyClass_get_1Uname__C (JNIEnv *env,
硬件手机和平板电脑内存太少,但 HAXM 工作正常? 我的基本问题是我的应用程序(很可能是我的 Java 应用程序加载的 JNI 动态库)太大。如果未使用硬件电话和模板调用 JNI 指令,Java 应
我正面临崩溃 JNI WARNING : 0x44f81e80 is not a valid JNI reference, in Ldalvik/system/NativeStart;. run()v
我移植了很多数学知识。我正在使用 over to c++ from java 并看到这样做有很大的性能提升,但我无法弄清楚要使用什么 jni 函数来摆脱我不再需要的变量。例如,我知道当您的 jni 方
我正在使用 JNI 调用一个静态 java 方法,该方法又创建一个 Swing JFrame 并显示它。代码相当简单,Java 代码独立运行(即 java StartAWT 做它应该做的事),而当使用
我正在尝试创建一个新线程,因此我将 VM 从我的方法初始化(从 Java 调用)传递到我的新线程。在线程中,我调用 AttachCurrentThread 并获取 JNIEnv* env。 稍后,我尝
我想知道是否有可能从java调用C++方法。 我非常希望能够从 java 读取内存进程。 我懂c++,但我想使用像java这样的更高级别,但仍然能够侵入进程内存。 有什么线索吗? []的 最佳答案 这
我是一名优秀的程序员,十分优秀!