首页 > 代码库 > JNI学习笔记
JNI学习笔记
JNI是什么-》一套c和java的互掉规则
为什么使用JNI
1.很多敏感效率的代码已经用C实现了
2. JNI双向,java调用c,c调用java
Java集成本地代码问题
1.代码移植,针对其他的平台需要重新编译库,.dll,.so
2.编码复杂了,需要处理掌握C和c++
1.JNI处理异常,不同于Java中的try...catch。在JNI中,发生异常,不会改变代码执行轨迹,所以,当返回NULL,要及时返回,或马上处理异常。
2.Java层的field和method,不管它是Public,还是package,private和protected,从JNI都可以访问到,Java面向语言的封装性不见了。
3.调用Java需要获取field与method IDs,需要做基于名称和签名的符号表查询,此过程可以被优化。思路:只在第一次使用ID时查询,然后缓存改值,有两个缓存时机:首次使用和初始化类时。
4.Java层对象作为opaque references传递到JNI层,是因为不希望JNI用户了解JNI内部数据结构.
5. signature:"(ILjava/lang/String;[I)J"
签名是一种用参数个数和类型区分同名方法的手段,即解决方法重载问题。
6. JNI支持三种类型的opaque reference: local references,global references和weak global references,local 和Global引用有不同的生命周期。Local Ref在nativemethod 执行完毕后被JavaVm自动释放,而Global需要手动释放。
6.1大部分JNI函数都会创建LocalRef,如NewObject创建一个实例,并返回一个指向该实例。LocalRef只在本线程的native method中有效.一旦native method 返回,localRef将被释放。不要缓存一个LocalRef,并企图在下次进入该JNI方法时使用
7.Android 调用JNI流程
1.编写XXX.java,里面包含System.loadLibrary()和Nativemethod的声明。
2.javah XXX.java生成 .h文件
3.编写.cpp实现.h中声明的方法
4.将.cpp编译成.so
8. .so只会在运行时加载,不参与编译。