一、常用命令 1.1、文件操作本文讲解在linux上开发jni,从没有linux小白到在linux上成功运行以下jni效果
创建文件夹
mkdir jdk
删除文件
rm -rf jdk
scp 上传命令
scp /Users/zhanglei/Downloads/jdk-8u333-linux-x64.tar.gz root@101.37.65.220:/usr/local/src/jdk
复制文件
cp 文件1 文件2
复制文件夹
cp -r zhanglei/ jason1.2、linux终端文本编辑
1、vim /etc/profile 2、编辑 按 i 键,进入编辑模式。 输入冒号 : 键,输入.点键 , 再按回车键,可看到“插入”显示 3、按esc ,进入命令模式 4、保存 输入冒号 : 键,再按 x 键,进入保存模式
按i进行编辑,保存按esc,然后输入:x按回车
生效
source /etc/profile
1.3、启动服务:wq命令与:x命令区别:
:wq 强制性写入文件并退出。即使文件没有被修改也强制写入,并更新文件的修改时间。
:x 写入文件并退出。仅当文件被修改时才写入,并更新文件修改时间,否则不会更新文件修改时间。
这个大家用不着,可以暂时不看
1、运行:./bin/www 2、查看端口是否被占用: lsof -i tcp:3000 3、重点->命令窗口输入:exit ,退出 4、查看Linux当前进程 ps aux | grep node 5、kill指定进程 kill -9 6913 6、启动服务并常驻进程 nohup ./bin/www & 7、查看日志 tail -200f nohup.out二、ndk入门 2.1、阿里云购买linux
2.2、配置oracle jdk阿里云新用户免费试用地址
优先选择ubuntu,次选centos
移除openjdk
sudo apt-get remove openjdk*
去下载Oracle jdk官网
scp 上传命令。本地上传到linux服务器
scp /Users/zhanglei/Downloads/jdk-8u333-linux-x64.tar.gz root@101.37.65.220:/usr/local/src/jdk
本地上传进度
服务器端ls查看
root@zhanglei:/usr/local/src/jdk# ls jdk-8u333-linux-x64.tar.gz
解压java
tar -zxvf jdk-8u333-linux-x64.tar.gz -C /usr/local/
配置路径
vim /etc/profile
按 Shift+g切换到最后一行,按o 切换至编辑模式
export JAVA_HOME=/usr/local/jdk1.8.0_333 #(您的 JDK 版本) export CLASSPATH=$JAVA_HOME/lib/tools.jar:$JAVA_HOME/lib/dt.jar:$JAVA_HOME/lib export PATH=$JAVA_HOME/bin:$PATH
添加完成,按Esc,输入:wq进行保存退出。更新环境变量
source /etc/profile
测试是否成功
root@zhanglei:/usr/local/src/jdk# java -version java version "1.8.0_333"2.3、安装gcc
gcc命令用于生成linux上的.so文件
sudo apt install gcc
安装build-essential
sudo apt install build-essential
查看版本
gcc --version2.4、编译动态库.so文件
拷贝头文件jni.h
cd /usr/local/jdk1.8.0_333/ cd include/ cp jni.h ~/zhanglei/
拷贝头文件jni_md.h
cd linux cp jni_md.h ~/zhanglei/
复制.h头文件
在工程下,生成.h头文件
cd src/main/java javah com.hs.demo.JNIDemo
并修改#include
为#include “jni.h”,接着在linux端通过vim命令把内容拷贝过去
vim com_hs_demo_JNIDemo.h
复制.c源文件
vim 01.c
接着把内容拷贝过去
#include "com_hs_demo_JNIDemo.h"
JNIEXPORT jstring JNICALL Java_com_hs_demo_JNIDemo_getStringFromC
(JNIEnv* env, jclass jcls) {
//env二级指针
//代表Java运行环境,调用Java中的代码
return (*env)->NewStringUTF(env, "Hello C String");
}
编译linux下的so动态库
gcc 01.c -fPIC -shared -o jni_study.so2.5、生成jar
首先需要安装maven环境,检查
mvn -v
如果没有需要从maven官网下载,或者直接在csdn上下载
配置mvn环境
1,打开终端,vi ~/.bash_profile
2,添加配置,地址改为你自己的解压文件地址
export M2_HOME=/Users/zhanglei/Documents/apache-maven-3.8.5 export PATH=$PATH:$M2_HOME/bin
3,终端输入,source ~/.bash_profile
4,终端输入mvn -v 查看是否安装成功
生成jar
idea新建maven工程选择webapp
如果遇到没有可选择的maven模板
关闭idea,然后从Welcome欢迎页进入
配置
包名com.hs.demo
工程名JNIDemo
耐心等待maven工程初始化完成.
在main目录下新建java,java下新建类com.hs.demo.JNIDemo。代码如下
public class JNIDemo {
public static void main(String[] args) {
System.out.println("收到jni:"+getStringFromC());
}
public native static String getStringFromC();
static {
//获取当前操作
String os = System.getProperty("os.name").toLowerCase();
if (os.contains("windows")) {
System.loadLibrary("jni_study");
} else if (os.contains("linux")) {
System.load("/root/zhanglei/jni_study.so");
}else{
System.loadLibrary("jni_study");
//也可以加载全路径
//System.load("/Users/zhanglei/Desktop/jni例子/jni_impl/build/release/libjni_study.dylib");
}
}
}
编辑pom文件
1,修改war包为jar包
2,java版本最好改为1.8。
3,build标签末尾添加程序入口
注意包名类名的一致
4.0.0 com.hs demo 1.0-SNAPSHOT jar UTF-8 1.8 1.8 junit junit 4.11 test JNIDemo maven-clean-plugin 3.1.0 maven-resources-plugin 3.0.2 maven-compiler-plugin 3.8.0 maven-surefire-plugin 2.22.1 maven-war-plugin 3.2.2 maven-install-plugin 2.5.2 maven-deploy-plugin 2.8.2 org.apache.maven.plugins maven-compiler-plugin 8 8 org.springframework.boot spring-boot-maven-plugin com.hs.demo.JNIDemo repackage
终端执行命令生成jar包,生成jar包的工程demo地址JNIDemo
mvn package
拷贝本地的javajni.jar文件到linux
scp /Users/zhanglei/IdeaProjects/JNIDemo/target/JNIDemo.jar root@101.37.65.220:/root/zhanglei2.6、运行结果
ls查看,已集齐“七龙珠”
然后执行,结果成功
java -jar javajni.jar



