http://blog.csdn.net/youjianbo_han_87/article/details/2586375
http://blog.csdn.net/yangjiali014/article/details/1633017
http://blog.chinaunix.net/space.php?uid=7437948&do=blog&id=2054823
http://www.iteye.com/topic/72543
http://www.enet.com.cn/article/2007/1029/A20071029886398.shtml
http://blog.csdn.net/heqingrong623/article/details/3906350
参考1:用JNI调用C或C++动态联接库原来如此简单
参考2:JNI技术实践小结
参考3:jni简单实例
今天在看java多线程编程的时候,发现Thread这个类中有多个native方法,以前从来没有见过这种方法,因此对于比较好奇,查阅了一些资料,现在整理一下,以作备忘。
native方法是通过java中的JNI实现的。JNI是Java Native Interface的 缩写。从Java 1.1开始,Java Native Interface (JNI)标准成为java平台的一部分,它允许Java代码和其他语言写的代码进行交互。JNI一开始是为了本地已编译语言,尤其是C和C++而设计 的,但是它并不妨碍你使用其他语言,只要调用约定受支持就可以了。使用java与本地已编译的代码交互,通常会丧失平台可移植性。但是,有些情况下这样做是可以接受的,甚至是必须的,比如,使用一些旧的库,与硬件、操作系统进行交互,或者为了提高程序的性能。JNI标准至少保证本地代码能工作在任何Java 虚拟机实现下。
目前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
public class HelloWorld { public native void displayHelloWorld();// java native方法申明 static { System.loadLibrary("HelloWorldImpl");// 装入动态链接库,"HelloWorldImpl"是要装入的动态链接库名称。 } public static void main(String[] args) { // TODO Auto-generated method stub HelloWorld helloWorld = new HelloWorld(); helloWorld.displayHelloWorld(); } }[java] view plaincopy
d:\JNI>javac HelloWorld.java执行完上述命令以后生成D:\JNI\HelloWorld.class文件
[java] view plaincopy
d:\JNI>javah -jni HelloWorld执行完上述命令以后生成D:\JNI\HelloWorld.h文件,该文件内容如下:
[java] view plaincopy
/* DO NOT EDIT THIS FILE - it is machine generated */ #include <jni.h> /* Header for class HelloWorld */ #ifndef _Included_HelloWorld #define _Included_HelloWorld #ifdef __cplusplus extern "C" { #endif /* * Class: HelloWorld * Method: displayHelloWorld * Signature: ()V */ JNIEXPORT void JNICALL Java_HelloWorld_displayHelloWorld (JNIEnv *, jobject); #ifdef __cplusplus } #endif #endif这里我们可以这样理解:这个h文件相当于我们在java里面的接口,这里声明了一个 Java_HelloWorld_displayHelloWorld (JNIEnv *, jobject);方法,然后在我们的本地方法里面实现这个方法,也就是说我们在编写C/C++程序的时候所使用的方法名必须和这里的一致
创建HelloWorldImpl.cpp,代码如下所示:
[java] view plaincopy
#include "HelloWorld.h" #include <stdio.h> #include <jni.h> /* * Class: HelloWorld * Method: displayHelloWorld * Signature: ()V */ JNIEXPORT void JNICALL Java_HelloWorld_displayHelloWorld (JNIEnv *, jobject) { printf("Hello World!\n"); return; }将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
cl/LD D:\JNI\HelloWorldImpl.cpp具体如下图所示:
执行完上述命令以后,我们在C:\Program Files (x86)\Microsoft Visual Studio 10.0\VC可以看到生成的四个文件,分别是:
HelloWorldImpl.dll HelloWorldImpl.exp HelloWorldImpl.lib HelloWorldImpl.obj将其中的HelloWorldImpl.dll拷贝到D:\JNI\目录下。
在cmd中运行:
[java] view plaincopy
d:\JNI>java HelloWorld具体如下图所示:
[java] view plaincopy
java.lang.UnsatisfiedLinkError: no HelloWorldImpl in java.library.path at java.lang.ClassLoader.loadLibrary(ClassLoader.java:1738) at java.lang.Runtime.loadLibrary0(Runtime.java:823) at java.lang.System.loadLibrary(System.java:1028) at HelloWorld.<clinit>(HelloWorld.java:6) 4.8将HelloWorldImpl.dll拷贝到C:\Windows\System32 4.9再次执行HelloWorld程序,程序正常运行,console输出“Hello World!”转载于:https://www.cnblogs.com/Gatsby/archive/2013/04/02/2996397.html
相关资源:各显卡算力对照表!