一个使用sbt编译的JNI C++ 的模板

假设你须要在Scala或是Java中调用C或C++函数库,就须要使用JNI。 这里就涉及到编译scala ,java 和C(C++)代码,在这里给出一个程序的框架,我们使用sbt 缺省的代码文件夹

文件文件夹
src
—>main
——–>java
——–>scala
——–>c

当中文件夹c存放C++代码 ,java文件夹放置Java代码, scala文件夹放置Scala代码

项目组用来编译的相关文件为build.sbt 和Makefile (它编译放置在c文件夹下的C++文件,注意仅仅能编译C++,假设你有须要编译C,须要自行改动Makefile)

改动库文件名称为自己所需的名称
改动build.sbt 中的项目名称

1 name := "JNIDemo"
2  
3 version := "0.0.1-SNAPSHOT"
4  
5 organization := "com.guidebee"

改动Makefile的库文件名称称

1 #### PROJECT SETTINGS ####
2 # The name of the executable to be created
3 SODIR = target/so
4 BIN_NAME= $(SODIR)/libjnidemo.so

改动Java引用的库文件名称称:

1 static {
2     System.loadLibrary("jnidemo");
3   }

环境变量设置
在你设置好sbt的编译环境后,注意设置 JAVA_HOME 和 LD_LIBRARY_PATH 环境变量 ,Java_HOME为你Java的安装文件夹, 能够使用
export LD_LIBRARY_PATH = $LD_LIBRARY_PATH:./:./target/so
将编译后的库文件加入到 java.library.path 路径中(这样Java代码能够找到库文件所在文件夹)

编译和执行
编译使用指令 sbt compile

1 [email protected]:/sdb/jni# sbt compile
2 [info] Set current project to JNIDemo (in build file:/mnt/sdb1/jni/)
3 [info] Compiling 3 Java sources to /mnt/sdb1/jni/target/scala-2.10/classes...
4 Creating directories
5 Beginning release build
6 Compiling: src/main/c/IntArray.cpp -> build/release/IntArray.o -Wall -Wextra -g -fPIC -c -O -m64 -Wunused-parameter
7 src/main/c/IntArray.cpp:21:1: warning: unused parameter ‘obj’ [-Wunused-parameter]
8  Java_IntArray_sumArray(JNIEnv *env, jobject obj, jintArray arr)
9  ^
10          Compile time: 00:00:00
11 Compiling: src/main/c/Prompt.cpp -> build/release/Prompt.o -Wall -Wextra -g -fPIC -c -O -m64 -Wunused-parameter
12 src/main/c/Prompt.cpp: In function ‘_jstring* Java_Prompt_getLine(JNIEnv*, jobject, jstring)’:
13 src/main/c/Prompt.cpp:24:13: warning: deprecated conversion from string constant to ‘char*’ [-Wwrite-strings]
14    char *buf="hello";
15              ^
16 src/main/c/Prompt.cpp: At global scope:
17 src/main/c/Prompt.cpp:22:1: warning: unused parameter ‘obj’ [-Wunused-parameter]
18  Java_Prompt_getLine(JNIEnv *env, jobject obj, jstring prompt)
19  ^
20          Compile time: 00:00:00
21 mkdir target/so
22 Linking: target/so/libjnidemo.so
23 #@g++ build/release/IntArray.o build/release/Prompt.o  -fPIC    -o target/so/libjnidemo.so
24          Link time: 00:00:00
25 Making library: target/so/libjnidemo.so -> target/so/libjnidemo.so
26 Total build time: 00:00:00
27 [success] Total time: 1 s, completed 29/08/2014 10:10:19 PM

执行
sbt run

1 [email protected]:/sdb/jni# sbt run
2 [info] Set current project to JNIDemo (in build file:/mnt/sdb1/jni/)
3 [info] Running Test
4 [info] User typed: hello
5 [info] sum = 45
6 [info] Type a line:
7 [success] Total time: 0 s, completed 29/08/2014 10:10:54 PM

删除编译结果
sbt clean

1 [email protected]:/sdb/jni# sbt clean
2 [info] Set current project to JNIDemo (in build file:/mnt/sdb1/jni/)
3 [info] Updating {file:/mnt/sdb1/jni/}jni...
4 [info] Resolving org.fusesource.jansi#jansi;1.4 ...
5 [info] Done updating.
6 Deleting target/so/libjnidemo.so symlink
7 Deleting directories
8 [success] Total time: 1 s, completed 29/08/2014 10:11:35 PM

Github 代码
本例模板代码能够在 https://github.com/guidebee/JNIDemo下载。

时间: 2024-10-12 18:17:06

一个使用sbt编译的JNI C++ 的模板的相关文章

Ubuntu下编译Android JNI实例全过程

第一步:保证make和gcc可用 在shell中输入make-v,不报错就是对的.(可参考http://wenku.baidu.com/view/d87586c24028915f804dc24a.html.) 在shell中输入gcc-v,不报错就是对的. 第二步:安装NDK 下载NDK后,设置环境变量: 将android-ndk的路劲加到环境变量PATH中:sudogedit /etc/environment 然后再让这个更改的环境变量立即生效:source /etc/environment

window环境下使用sbt编译spark源码

前些天用maven编译打包spark,搞得焦头烂额的,各种错误,层出不穷,想想也是醉了,于是乎,换种方式,使用sbt编译,看看人品如何! 首先,从官网spark官网下载spark源码包,解压出来.我这边使用的是1.4.0版本. 然后,我们需要把sbt配置好,配置很简单,无非就是SBT_HOME什么的,大家可以参考官网给出的安装配置手册. 在window的命令行模式下进入刚刚解压的spark源码目录下,我们根据官网提示的命令输入: sbt -Pyarn -Phadoop-2.3 assembly

【Android】Eclipse自己主动编译NDK/JNI的三种方法

[Android]Eclipse自己主动编译NDK/JNI的三种方法 SkySeraph Sep. 18th  2014 Email:[email protected] 一.Eclipse关联cygwin 1. project->右击选择Properties->选择Builders,在Builders中选择New创建一个Program 2. 參数配置 二.Eclipse关联ndk-build(自建Builder方法)  1. Project->Properties->Builder

【Android】Eclipse自动编译NDK/JNI的三种方法

[Android]Eclipse自动编译NDK/JNI的三种方法 SkySeraph Sep. 18th  2014 Email:[email protected] 一.Eclipse关联cygwin 1. 工程->右击选择Properties->选择Builders,在Builders中选择New创建一个Program 2. 参数配置 二.Eclipse关联ndk-build(自建Builder方法)  1. Project->Properties->Builders->N

用SBT编译Spark的WordCount程序

问题导读: 1.什么是sbt? 2.sbt项目环境如何建立? 3.如何使用sbt编译打包scala? sbt介绍 sbt是一个代码编译工具,是scala界的mvn,可以编译scala,java等,需要java1.6以上. sbt项目环境建立 sbt编译需要固定的目录格式,并且需要联网,sbt会将依赖的jar包下载到用户home的.ivy2下面,目录结构如下: |--build.sbt |--lib |--project |--src | |--main | | |--scala | |--tes

sbt编译spark程序提示value toDF is not a member of Seq()

sbt编译spark程序提示value toDF is not a member of Seq() 前提 使用Scala编写的Spark程序,在sbt编译打包的时候提示value toDF is not a member of Seq(),出问题的代码如下: val urlDS = Seq(STU(age, count)).toDS() 其中STU是一个定义的case class,定义如下: case class STU(age: Int, count: Int) 查找原因 开始以为是toDS(

如何写一个解释器(1):编译原理

最近在看DSL的东西,对于外部DSL,写一个解释器是必不可少的.我试图归纳一下我学到的,以写一个解释器为目标,讲一下如果来实现一个可用的解释器.一个解释器通常可以分为一下几个阶段: 词法分析(Lexer) 语法分析(Parser, BNF, CFG, AST) 语义分析(AST的处理, annotated AST) 目标语言生成(stack-based) 这里的解释器不包括目标语言的执行和运行时环境,如果需要类似于python/ruby的解析执行器的话,还需要bytecode-compiler,

Spark-1.0.1 的make-distribution.sh编译、SBT编译、Maven编译 三种编译方法

本文编译方法所支持的hadoop环境是Hadoop-2.2.0,YARN是2.2.0,JAVA版本为1.8.0_11,操作系统Ubuntu14.04 Spark1.0.0 源码下载地址: http://mirror.bit.edu.cn/apache/spark/spark-1.0.0/spark-1.0.0.tgz Spark1.0.1 源码下载地址:http://apache.fayea.com/apache-mirror/spark/spark-1.0.1/spark-1.0.1.tgz

原已经安装好的nginx,现在需要添加一个未被编译安装的模块--echo-nginx-module-0.56

为了测试一个NGINX变量,将NGINX加了一个编译模板echo-nginx-module-0.56. 参照如下文件 1,先看以前NGINX有哪些东东. sbin/nginx -Vnginx version: nginx/1.6.0built by gcc 4.4.7 20120313 (Red Hat 4.4.7-11) (GCC) TLS SNI support enabledconfigure arguments: --prefix=/XXXX/lnmp/nginx --user=ngin