CentOS는 다운로드를 NDK 및 동적 라이브러리 정적 라이브러리를 컴파일
텐센트 클라우드로 사용 iTerm2 RZ SZ Mac 및 전송 파일
ndkdir 디렉토리에 libget.so libget.a 및 추가 및 파일 Android.mk를 만들
구성 build.gradle을
externalNativeBuild {
ndkBuild {
abiFilters 'armeabi-v7a'
// abiFilters 'x86'
}
}
// 手动写一个mk 的构建方式
externalNativeBuild {
ndkBuild {
path 'src/main/ndkdir/Android.mk'
}
}
ndkVersion = '21.0.6113669'
login.c
#include <jni.h>
#include <android/log.h>
// 声明一个函数
extern int get();
JNIEXPORT void JNICALL Java_com_hongx_jnitest_MainActivity_getMyLibMethod
(JNIEnv * env, jobject inst) {
__android_log_print(ANDROID_LOG_DEBUG, "Hongx", "tesegetMEthod:%d", get());
}
Android.mk
# 这里面能够决定编译 Login.c
# 1.源文件在的位置。宏函数 my-dir 返回当前目录(包含 Android.mk 文件本身的目录)的路径。
# LOCAL_PATH 其实就是Android.mk文件本身的目录的路径
LOCAL_PATH := $(call my-dir)
$(info "LOCAL_PATH:======== ${LOCAL_PATH}")
# 2.清理
include $(CLEAR_VARS)
# TODO 预编译库的引入 == 提前编译好的库
LOCAL_MODULE := get
LOCAL_SRC_FILES := libget.a
# LOCAL_SRC_FILES := libget.so
# 预编译共享库的Makeifle脚本
include $(PREBUILT_STATIC_LIBRARY)
#include $(PREBUILT_SHARED_LIBRARY)
#引入其他makefile文件。CLEAR_VARS 变量指向特殊 GNU Makefile,可为您清除许多 LOCAL_XXX 变量
#不会清理 LOCAL_PATH 变量
include $(CLEAR_VARS)
# TODO end
# 3.指定库名字
#存储您要构建的模块的名称 每个模块名称必须唯一,且不含任何空格
#如果模块名称的开头已是 lib,则构建系统不会附加额外的前缀 lib;而是按原样采用模块名称,并添加 .so 扩展名。
LOCAL_MODULE := MyLoginJar
#包含要构建到模块中的 C 和/或 C++ 源文件列表 以空格分开
LOCAL_SRC_FILES := Login.c \
Test.c
# TODO 开始链接进来
# 静态库的链接
LOCAL_STATIC_LIBRARIES := get
# 动态库链接
# LOCAL_SHARED_LIBRARIES := get
# 导入 log
#LOCAL_LDLIBS := -llog
LOCAL_LDLIBS := -lm -llog
# 4.动态库
#构建动态库BUILD_SHARED_LIBRARY 最后要动态库
include $(BUILD_SHARED_LIBRARY)
MainActivity
public class MainActivity extends AppCompatActivity {
static {
System.loadLibrary("MyLoginJar"); // 加载总库
}
@Override
protected void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.activity_main);
getMyLibMethod();;
}
public native void getMyLibMethod();
}