【转发】Jni解决了哪些问题?,转发jni解决
分享于 点击 47492 次 点评:24
【转发】Jni解决了哪些问题?,转发jni解决
TODO http://www.cnblogs.com/mandroid/archive/2011/06/15/2081093.html
http://blog.sina.com.cn/s/blog_53a7e8a30101lgdu.html
http://wenku.it168.com/d_000596600.shtml
JNI是Java Native Interface(Java本地接口)的缩写。
JAVA通过JNI调用本地方法,而本地方法是以库文件的形式存放的(在WINDOWS平台上是DLL文件形式,在UNIX机器上是SO文件形式,在LNUIX机器上是ELF文件形式)
内存管理 堆对象,注意释放内存
通过jni创建的对象,都是使用jvm的heap空间。比如jstring、jarray等继承于jobject的类内存的分配实际上都是由jvm管理的,并不是使用c的本地内存。如以下代码片段创建了一个String对象,这个对象可以被以jstring的方式传递给jni框架的调用者,最终在jvm的heap里创建了一个内容为"hello world!"的String对象
char *buf = "hello world!";
(*env)->NewStringUTF(env, buf);
在jni代码里,任何jni基本类型的指针或者对象的创建都是通过直接分配内存的,如果创建的对象是被返回给jni调用者的,那么可以不用管理该对象的内存。如果是临时使用,则必须在使用完成之后释放内存
应用场景(性能:图形处理,调用驱动,使用大内存(进程内),调用操作系统服务)
总结了一下,jni一般有以下一些应用场景
1.高性能 ,在一些情况下因为处理运算量非常大,为了获取高性能,直接使用java是不能胜任的,如:一些图形的处理
2.调用一些硬件的驱动或者一些软件的驱动,比如调用一些外部系统接口的驱动,如:读卡器的驱动,OCI驱动
3.需要使用大内存,远远超过jvm所能分配的内存,如:进程内Cache缓存
4.调用C或者操作系统提供的服务,如:java调用搜索服务,其中搜索是由C/C++实现的,不过这个一般可以设计成更加通用的方式,比如soa的方式
所有这些场景的前提是牺牲了java代码的可移植性,不同的os,甚至版本都需要写不同版本的native实现
性能
java既然运行在jvm之上,那么jvm又是怎么和操作系统交互的呢?jvm是由c语言写成,对java的接口进行了优化,性能非常的好。
http://jjw.iteye.com/blog/627267
相关文章
- 暂无相关文章
用户点评