最近遇见一个java中一个native关键字,不知道是干什么的,以下:java
public native String FileName(String strURL);
static{
System.loadLibrary("fill-jni");
}linux
上网查了下,在众多的参考资料中,下面这个连接写的仍是蛮不错的:c++
http://blog.csdn.net/xw13106209/article/details/6989415编程
如下为转载,其中部分有备注(红色字体部分),记录一下遇到的问题。windows
native是与C++联合开发的时候用的!使用native关键字说明这个方法是原生函数,也就是这个方法是用C/C++语言实现的,而且被编译成了DLL,由java去调用。 这些函数的实现体在DLL中,JDK的源代码中并不包含,你应该是看不到的。对于不一样的平台它们也是不一样的。这也是java的底层机制,实际上java就是在不一样的平台上调用不一样的native方法实现对操做系统的访问的。总而言之:eclipse
native方法是经过java中的JNI实现的。JNI是Java Native Interface的 缩写。从Java 1.1开始,Java Native Interface (JNI)标准成为java平台的一部分,它容许Java代码和其余语言写的代码进行交互。JNI一开始是为了本地已编译语言,尤为是C和C++而设计 的,可是它并不妨碍你使用其余语言,只要调用约定受支持就能够了。使用java与本地已编译的代码交互,一般会丧失平台可移植性。可是,有些状况下这样作是能够接受的,甚至是必须的,好比,使用一些旧的库,与硬件、操做系统进行交互,或者为了提升程序的性能。JNI标准至少保证本地代码能工做在任何Java 虚拟机实现下。jvm
目前java与dll交互的技术主要有3种:jni,jawin和jacob。Jni(Java Native Interface)是sun提供的java与系统中的原生方法交互的技术(在windows\linux系统中,实现java与native method互调)。目前只能由c/c++实现。后两个都是sourceforge上的开源项目,同时也都是基于jni技术的windows系统上的一个应用库。Jacob(Java-Com Bridge)提供了java程序调用microsoft的com对象中的方法的能力。而除了com对象外,jawin(Java/Win32 integration project)还能够win32-dll动态连接库中的方法。就功能而言:jni >> jawin>jacob,其大体的结构以下图:函数
就易用性而言,正好相反:jacob>jawin>>jni。性能
Jvm封装了各类操做系统实际的差别性的同时,提供了jni技术,使得开发者能够经过java程序(代码)调用到操做系统相关的技术实现的库函数,从而与其余技术和系统交互,使用其余技术实现的系统的功能;同时其余技术和系统也能够经过jni提供的相应原生接口开调用java应用系统内部实现的功能。测试
在windows系统上,通常可执行的应用程序都是基于native的PE结构,windows上的jvm也是基于native结构实现的。Java应用体系都是构建于jvm之上。
Jni对于应用自己来讲,能够看作一个代理模式。对于开发者来讲,须要使用c/c++来实现一个代理程序(jni程序)来实际操做目标原生函数,java程序中则是jvm经过加载并调用此jni程序来间接地调用目标原生函数。
下列是全部操做都是在目录:D:\JNI 下进行的,这样作的好处是便于控制。还有另一个要求是咱们的java类不含包名,当前我只测试成功不含包名的类型。
[java] view plaincopy
[java] view plaincopy
执行完上述命令之后生成D:\JNI\HelloWorld.class文件
注:在这一步中遇到了一个历来没有遇到过的错误,我是用过notepad++写的上面程序,用这个命令编译后出现下面的错误:
缘由是由于我使用的notepad++编码方式是UTF-8,改为ANSI编码方式后就能够解决上面的问题了。
3.3.使用javah -jni java类名生成扩展名为h的头文件
[java] view plaincopy
注:使用javah/h 能够查看帮助。以下:
用法:
javah [options] <classes>其中, [options] 包括:
-o <file> 输出文件 (只能使用 -d 或 -o 之一)
-d <dir> 输出目录
-v -verbose 启用详细输出
-h --help -? 输出此消息
-version 输出版本信息
-jni 生成 JNI 样式的标头文件 (默认值)
-force 始终写入输出文件
-classpath <path> 从中加载类的路径
-bootclasspath <path> 从中加载引导类的路径
<classes> 是使用其全限定名称指定的
(例如, java.lang.Object)。
执行完上述命令之后生成D:\JNI\HelloWorld.h文件,该文件内容以下:
[java] view plaincopy
这里咱们能够这样理解:这个h文件至关于咱们在java里面的接口,这里声明了一个 Java_HelloWorld_displayHelloWorld (JNIEnv *, jobject);方法,而后在咱们的本地方法里面实现这个方法,也就是说咱们在编写C/C++程序的时候所使用的方法名必须和这里的一致
建立HelloWorldImpl.cpp,代码以下所示:
[java] view plaincopy
好吧,错误还真很多,个人路走的还挺坎坷……找啊,找啊……找到的解决方法以下:
找到你的虚拟机安装目录,将其下面的三个文件,以下:
\jdk\include\jni.h
\jdk\include\win32\jawt_md.h
\jdk\include\win32\jni_md.h
分别复制它们到vc目录下的include文件夹下,必定是include文件夹啊,里面有好多的.h文件……
而后再运行,就没有错了,若是你在这儿不修正这个错误,下面在你编译dll文件的时候,还得修复!
将D:\Program Files\Java\jdk1.6.0_26\include\jni.h和D:\Program Files\Java\jdk1.6.0_26\include\win32\jni_md.h这两个文件拷贝到D:\JNI\目录下。与HelloWorldImpl.cpp同目录,目录结构以下图所示:
我使用的是visual studio 2010,要使用其中的cl命令,必须打开visual studio 命令行,以下图所示:
而后再命令行中输入以下命令
[java] view plaincopy
具体以下图所示:
执行完上述命令之后,咱们在C:\Program Files (x86)\Microsoft Visual Studio 10.0\VC能够看到生成的四个文件,分别是:
将其中的HelloWorldImpl.dll拷贝到D:\JNI\目录下。
注:若是你找不到这四个文件,将目录向上推一级吧……或许你就看到了……
在cmd中运行:
[java] view plaincopy
具体以下图所示:
我真想说一句,你妹的。解决方案是……网上说,换虚拟机,由于个人虚拟机是64位的,32位的dll文件不能运行。解决方法以下:
解决方法来自:http://blog.csdn.net/gumanren/article/details/6455991
1.从新下载一个32位的虚拟机,例如:jre-6u23-windows-i586.exe
2.安装虚拟机,目录所在位置——例如:C:/Java/jre-6u23-windows-i586
2.卸载WTK
3.安装WTK,虚拟机地址,选择2步骤,的目录地址
4.重启eclipse,找到设备管理器,更新模拟器位置。
5.OK!
到底能不能ok我是没有时间去试验了……暂时还不想从新装虚拟机……还有好多事情要忙……因此初探java的native到此结束……
但愿能够对你有帮助,嘿嘿……按照这位仁兄写的东西,文件已经整出来了,以下:
就是由于虚拟机不兼容问题运行不了,我打包一下放在csdn论坛里,你能够下载一下,可是你的虚拟机得是32位啊,要否则,你下载了也白下……
下载地址:http://download.csdn.net/detail/still_ice_water/6363107
[java] view plaincopy