Warning: file_get_contents(/data/phpspider/zhask/data//catemap/3/android/197.json): failed to open stream: No such file or directory in /data/phpspider/zhask/libs/function.php on line 167

Warning: Invalid argument supplied for foreach() in /data/phpspider/zhask/libs/tag.function.php on line 1116

Notice: Undefined index: in /data/phpspider/zhask/libs/function.php on line 180

Warning: array_chunk() expects parameter 1 to be array, null given in /data/phpspider/zhask/libs/function.php on line 181
从C代码创建JAVA类_Java_Android_C_Native Code_Native Methods - Fatal编程技术网

从C代码创建JAVA类

从C代码创建JAVA类,java,android,c,native-code,native-methods,Java,Android,C,Native Code,Native Methods,我在java中有一个名为XMLDOMDocument的类,这个类有一些方法CreateXML,AddNode,RemoveNode等等。我在java本机接口的帮助下从C代码调用这个方法,但是为了实现这个目的,我通过调用env->GetObjectClass(myclass)传递给java类的C代码对象我从该对象获取类,并调用JAVA类的方法 我想知道我是否可以在不将类传递给C代码的情况下做同样的事情(调用JAVA方法)。我可以在C代码中创建JAVA类,然后调用它的方法吗 已编辑 如果我的C代码中

我在java中有一个名为
XMLDOMDocument
的类,这个类有一些方法
CreateXML
AddNode
RemoveNode
等等。我在java本机接口的帮助下从C代码调用这个方法,但是为了实现这个目的,我通过调用
env->GetObjectClass(myclass)传递给java类的C代码对象
我从该对象获取类,并调用JAVA类的方法

我想知道我是否可以在不将类传递给C代码的情况下做同样的事情(调用JAVA方法)。我可以在C代码中创建JAVA类,然后调用它的方法吗

已编辑

如果我的C代码中有JavaVM,我可以在JavaVM的帮助下在C代码中创建一个新的JAVA类实例

已编辑

我想我发现了一些有用的东西,但我想知道必须存储什么值
#define USER_CLASSPATH
?如果必须是包名
com.fido.android.framework.service

public class Prog {
     public static void main(String[] args) {
          System.out.println("Hello World " + args[0]);
     }
 }

#include <jni.h>

 #define PATH_SEPARATOR ';' /* define it to be ':' on Solaris */
 #define USER_CLASSPATH "." /* where Prog.class is */

 main() {
     JNIEnv *env;
     JavaVM *jvm;
     jint res;
     jclass cls;
     jmethodID mid;
     jstring jstr;
     jclass stringClass;
     jobjectArray args;

 #ifdef JNI_VERSION_1_2
     JavaVMInitArgs vm_args;
     JavaVMOption options[1];
     options[0].optionString =
         "-Djava.class.path=" USER_CLASSPATH;
     vm_args.version = 0x00010002;
     vm_args.options = options;
     vm_args.nOptions = 1;
     vm_args.ignoreUnrecognized = JNI_TRUE;
     /* Create the Java VM */
     res = JNI_CreateJavaVM(&jvm, (void**)&env, &vm_args);
 #else
     JDK1_1InitArgs vm_args;
     char classpath[1024];
     vm_args.version = 0x00010001;
     JNI_GetDefaultJavaVMInitArgs(&vm_args);
     /* Append USER_CLASSPATH to the default system class path */
     sprintf(classpath, "%s%c%s",
             vm_args.classpath, PATH_SEPARATOR, USER_CLASSPATH);
     vm_args.classpath = classpath;
     /* Create the Java VM */
     res = JNI_CreateJavaVM(&jvm, &env, &vm_args);
 #endif /* JNI_VERSION_1_2 */

     if (res < 0) {
         fprintf(stderr, "Can't create Java VM\n");
         exit(1);
     }
     cls = (*env)->FindClass(env, "Prog");
     if (cls == NULL) {
         goto destroy;
     }

     mid = (*env)->GetStaticMethodID(env, cls, "main",
                                     "([Ljava/lang/String;)V");
     if (mid == NULL) {
         goto destroy;
     }
     jstr = (*env)->NewStringUTF(env, " from C!");
     if (jstr == NULL) {
         goto destroy;
     }
     stringClass = (*env)->FindClass(env, "java/lang/String");
     args = (*env)->NewObjectArray(env, 1, stringClass, jstr);
     if (args == NULL) {
         goto destroy;
     }
     (*env)->CallStaticVoidMethod(env, cls, mid, args);

 destroy:
     if ((*env)->ExceptionOccurred(env)) {
         (*env)->ExceptionDescribe(env);
     }
     (*jvm)->DestroyJavaVM(jvm);
 }
公共类程序{
公共静态void main(字符串[]args){
System.out.println(“Hello World”+args[0]);
}
}
#包括
#定义路径_分隔符“;”/*在Solaris上将其定义为“:”*/
#定义用户_CLASSPATH”“/*其中Prog.class是*/
main(){
JNIEnv*env;
JavaVM*jvm;
金特雷斯;
jclass cls;
jmethodidemid;
jstring-jstr;
jclass stringClass;
jobjectArray参数;
#ifdef JNI_版本1_2
JavaVMInitArgs vm_args;
JavaVMOption选项[1];
选项[0]。选项字符串=
“-Djava.class.path=”用户\类路径;
vm_args.version=0x00010002;
vm_args.options=选项;
vm_args.nOptions=1;
vm_args.ignoreunrecogned=JNI_TRUE;
/*创建JavaVM*/
res=JNI_CreateJavaVM(&jvm,(void**)&env,&vm_args);
#否则
JDK1_1nitargs vm_args;
字符类路径[1024];
vm_args.version=0x0000001;
JNI_GetDefaultJavaVMInitArgs(&vm_args);
/*将用户\类路径附加到默认系统类路径*/
sprintf(类路径,“%s%c%s”,
vm_args.classpath、PATH_分隔符、USER_classpath);
vm_args.classpath=类路径;
/*创建JavaVM*/
res=JNI_CreateJavaVM(&jvm,&env,&vm_args);
#endif/*JNI_版本1_2*/
如果(res<0){
fprintf(stderr,“无法创建Java VM\n”);
出口(1);
}
cls=(*env)->FindClass(env,“Prog”);
如果(cls==NULL){
去摧毁;
}
mid=(*env)->GetStaticMethodID(env,cls,“main”,
“([Ljava/lang/String;)V”);
if(mid==NULL){
去摧毁;
}
jstr=(*env)->NewStringUTF(env,“来自C!”);
if(jstr==NULL){
去摧毁;
}
stringClass=(*env)->FindClass(env,“java/lang/String”);
args=(*env)->NewObjectArray(env,1,stringClass,jstr);
如果(args==NULL){
去摧毁;
}
(*env)->CallStaticVoidMethod(env、cls、mid、args);
销毁:
如果((*env)->发生异常(env)){
(*env)->例外说明(env);
}
(*jvm)->破坏JavaVM(jvm);
}

我还想知道从java向C传递类对象和在C中创建java类之间的区别,类路径的定义应该与启动java虚拟机时传递它的方式相同d C可执行文件位于某个目录中,编译的Java类位于com/fido/android/framework/service子目录中

包名称应在FindClass调用中传递:

cls = (*env)->FindClass(env, "com/fido/android/framework/service/Prog");

@mavropovato,如果我的c文件不能与java类位于同一目录中,我必须如何指定路径?例如,我的c项目位于c:/projects/newproject/mycfile.c中,java类位于c:/java\u projects/scr/com/android/fido/…您可以将类路径指向类文件所在的目录,但我不推荐它。Remem在C语言中,如果你定义了一些东西,你需要重新编译以改变它。对我来说,最好的解决方案是将你所有的类文件打包在一个jar中,相对于你的可执行文件,并将你的类路径指向那里