2022年Java进阶-JNI使用技巧点滴软件教程.docx
-
资源ID:35441309
资源大小:14.81KB
全文页数:10页
- 资源格式: DOCX
下载积分:9.9金币
快捷下载
会员登录下载
微信登录下载
三方登录下载:
微信扫一扫登录
友情提示
2、PDF文件下载后,可能会被浏览器默认打开,此种情况可以点击浏览器菜单,保存网页到桌面,就可以正常下载了。
3、本站不支持迅雷下载,请使用电脑自带的IE浏览器,或者360浏览器、谷歌浏览器下载即可。
4、本站资源下载后的文档和图纸-无水印,预览文档经过压缩,下载后原文更清晰。
5、试题试卷类文档,如果标题没有明确说明有答案则都视为没有答案,请知晓。
|
2022年Java进阶-JNI使用技巧点滴软件教程.docx
2022年Java进阶:JNI使用技巧点滴软件教程本文为在 32 位 Windows 平台上实现 Java 本地方法供应了好用的示例、步骤和准则。本文中的示例运用 Sun Microsystems 公司创建的 Java Development Kit (JDK) 版本 1.4.1。用 C 语言编写的本地代码是用 Microsoft Visual C+ 编译器编译生成。简介近日,由于项目须要,要在WEB页面实现图像转换功能,而VC在图像转换方面有着得天独厚的优势。我们首先用VC封装出图像转换的DLL,然后用JAVA的本地化方法JNI调用用于图像转换的DLL,最终用JavaBean调用JNI生成的DLL。通过近几天在网上找资料和自己的摸索,收获许多,现总结如下,让以后做这方面的人少走弯路。一. JAVA部分1. 无包的状况:实例一:说明:1)在JAVA程序中,首先须要在类中声明所调用的库名称System.loadLibrary( String libname );,在库的搜寻路径中定位这个库。定位库的详细操作依靠于操作系统。在windows下,首先从当前书目查找,然后再搜寻”PATH”环境变量列出的书目。假如找不到该库,则会抛出UnsatisfiedLinkError。2)这里加载的是JNI生成的DLL,而不是其他生成的DLL的名称。 在这里,库的扩展名字可以不用写出来,原委是DLL还是SO,由系统自己推断。3) 还须要对将要调用的方法做本地声明,关键字为native。并且只须要声明,而不须要详细实现。 实现放在C中实现,稍后将做说明。4)假如加了static,表明是静态方法。假如不加,表明是一般的方法。加与不加,生成的头文件中有一个参数不同。稍后将做说明。现在起先编译它:用javac MyNative.h编译它,生成对应的class文件。用javah MyNative ,就会生成对应的MyNative.h头文件。剩下的是就起先交给VC来完成了(我们用VC来实现对应的C实现部分)。2. 有包的状况:实例二:其他与上面相同,就是在用javac和javah时有所不同。对于有包的状况肯定要留意这一点,起先时我的程序始终运行都不胜利,问题就出在这里。上面一句就不用说明了。对下面的一句说明一下:本类的前面均是包名。这样生成的头文件就是:com.myNative.MyNative.h。 起先时,在这种状况下我用javah MyNative生成的头文件始终是MyNative.h。在网上查资料时,望见别人的头文件名砸那长,我的那短。但不知道为什么,现在大家和我一样知道为什么了吧。:)。有时还须要带上路径。详细查看javah的语法。二C实现部分刚才用javah MyNative生成的MyNative.h头文件内容如下:接下来,就是如何实现它了。其实,用JNI作出的东西也是DLL,被JAVA所调用。在详细实现的时候,我们只关切两个函数原型:现在让我们起先激烈人心的第一步吧 : ) 。在project里面选择win32 Dynamic-link Library,然后点击下一步,其余的取默认。假如不取默认的,将会有dllmain()函数。取空DLL工程的话,将无这个函数。我在这里取的是空。然后选择new->File->C+ Source File,生成一个空*.cpp文件。我们把他取名为MyNative。把JNIEXPORT void JNICALL Java_MyNative_HelloWord(JNIEnv *, jclass);和JNIEXPORT jstring JNICALL Java_MyNative_cToJava(JNIEnv *, jclass);拷贝到CPP文件中去。然后把头文件包含进来。生成的MyNative.cpp内容如下:在编译前肯定要留意下列状况。留意:肯定要把SDK中的include文件夹中(和它下面的win32文件夹下的头文件)的几个头文件拷贝到VC的include文件夹中。或者在VC的toolsoptionsdirectories中设置,把头文件给包含进来。对程序的一点说明:1)前文不是说过,加了static和不加只是一个参数的区分吗。就是jclass的不同,不加static这里就是jobject。也就是JNIEXPORT void JNICALL Java_MyNative_HelloWord(JNIEnv *env, jobject obj)。2)这里JNIEXPORT和JNICALL都是JNI的关键字,表示此函数是要被JNI调用的。而jstring是以JNI为中介使JAVA的String类型与本地的string沟通的一种类型,我们可以视而不见,就当做String运用(详细对应见表一)。函数的名称是JAVA_再加上java程序的package路径再加函数名组成的(参见有包的状况)。参数中,我们也只须要关切在JAVA程序中存在的参数,至于JNIEnv*和jclass我们一般没有必要去碰它。3)NewStringUTF()是JNI函数,从一个包含UTF格式编码字符的char类型数组中创建一个新的jstring对象。4) 以上程序片断jstr=env->NewStringUTF(str);是C+中的写法,不必运用env指针。因为JNIEnv函数的C+版本包含有干脆插入成员函数,他们负责查找函数指针。而对于C的写法,应改为:jstr=(*env)->NewStringUTF(env,str);因为全部JNI函数的调用都运用env指针,它是随意一个本地方法的第一个参数。env指针是指向一个函数指针表的指针。因此在每个JNI函数访问前加前缀(*env)->,以确保间接引用函数指针。在C和Java编程语言之间传送值时,须要理解这些值类型在这两种语言间的对应关系。这些都在头文件jni.h中,用typedef语句声明白这些类在目标平台上的代价类。头文件也定义了常量如:JNI_FALSE=0 和JNI_TRUE=1;表一说明白Java类型和C类型之间的对应关系。表一 Java类型和C类型现在起先对所写的程序进行编译。选择build->rebuild all对所写的程序进行编译。点击build->build MyNative.DLL生成DLL文件。也可以用吩咐行cl来编译。详细参看其他书籍。再次强调(曾经为这个东西大伤脑筋):DLL放置地方1) 当前书目。2) 放在path所指的路径中3) 自己在path环境变量中设置一个路径,要留意所指引的路径应当到.dll文件的上一级,假如指到.dll,则会报错。下面就起先测试我们的所写的DLL吧(假设DLL已放置正确)。留意也要把MyNative.class放在与mytest.java同一个路径下。现在起先编译运行mytest,是不是在DOS窗口上输出:以上是我们通过JNI方法调用的一个简洁C程序。但在实际状况中要比这困难的多。特殊是在通过JNI调用其他DLL时,还有许多的地方须要留意。现在起先来探讨包含包的状况,步骤与上面的相同,只是有一点点不同。我们来看其中的一个函数。我们来视察函数名称。函数的名称是JAVA_再加上java程序的package路径再加函数名组成的。现在这句话应当理解了吧。我们也写一个程序来测试包含包的状况。程序略。是不是在DOS窗口上也显示同样的内容:)。这次,就到这里吧,下一讲将讲解并描述JNI调用其他DLL时应当留意的地方,同时会给出一个详细的例子。也将会给出一个UNICODE编码和ASCII编码之间相互转换的通用函数。