首页 > 代码库 > JNI测试-java调用c算法并返回java调用处-1到20阶乘的和
JNI测试-java调用c算法并返回java调用处-1到20阶乘的和
一,java端:
定义native方法, ‘public native long factorial(int n);‘, 该方法用c/c++实现,计算‘1到20阶乘的和‘,参数中‘int n‘是前n项的阶乘的和(这里是20).返回计算结果,并返回java调用处.
代码为:
1 public class FactorialJava { 2 3 public native long factorial(int n); 4 5 //evaluate the elapse time.and the execution result. 6 public long elapse() { 7 long start = System.currentTimeMillis(); 8 9 // code executing time.10 long sumResult = factorial(20);11 12 System.out.println("sum_result:" + sumResult);13 14 long end = System.currentTimeMillis();15 return end - start;16 }17 18 //load the dll library before executing conductive code.19 static {20 System.loadLibrary("FactorialDll");21 }22 23 public static void main(String[] args) {24 FactorialJava fac = new FactorialJava();25 System.out.println("耗时: " + fac.elapse() + " 毫秒");26 }27 28 }
二,c/c++在vs中新建一个能产生dll动态链接库的项目,并实现java中定义的native方法.代码如下:
1 jlong 2 recesive_fac(jint n) { 3 if(n == 1) 4 return 1; 5 else 6 { 7 return n * recesive_fac(n - 1); 8 } 9 }10 11 //使用jni循环递归过程,将结果返回java调用处.12 JNIEXPORT jlong JNICALL Java_FactorialJava_factorial13 (JNIEnv *env, jobject obj, jint n) {14 jlong sum = 0; 15 //const jint n = 20;16 for(int i = 1; i <= n; i++) {17 sum += recesive_fac(i);18 }19 20 return sum;21 }
其中,调用过程需要引入的额外头文件,配置eclipse中的classpath的步骤在博客中的 java JNI 的实现(1)-又进一步加深对JVM实现的理解 中.
JNI测试-java调用c算法并返回java调用处-1到20阶乘的和
声明:以上内容来自用户投稿及互联网公开渠道收集整理发布,本网站不拥有所有权,未作人工编辑处理,也不承担相关法律责任,若内容有误或涉及侵权可进行投诉: 投诉/举报 工作人员会在5个工作日内联系你,一经查实,本站将立刻删除涉嫌侵权内容。