①我在项目中引用了第三方的C库,以源码形式引用的。
在我JNI的C文件中已经引入了第三方的头文件。然后通过NDK编译的时候,使用到的第三方库的函数提示未定义。

此时的mk文件写法:
LOCAL_PATH := $(call my-dir)
include $(CLEAR_VARS)
LOCAL_MODULE := EmvHandler
LOCAL_SRC_FILES := EmvHandler.c
include $(BUILD_SHARED_LIBRARY)
后来在网上查,说在mk里也需要引入使用到的头文件的路径,于是修改为:
LOCAL_PATH := $(call my-dir)但是这样编译提示
include $(CLEAR_VARS)
LOCAL_MODULE := EmvHandler
LOCAL_SRC_FILES := EmvHandler.c\
EmvLib_Api.h
include $(BUILD_SHARED_LIBRARY)

这样编译应该没成功,虽然没提示具体错误,但是android程序运行报错了。请问这种在JNI的C文件中引用了第三方库的情况,mk文件倒底该怎么写?或是其它需要注意的地方?
②第三方的库中有很多结构体。我这里举个例
typedef struct {
unsigned char RID[5];
unsigned char KeyID;
unsigned long HashInd;
}EMV_TEST;第三方库中有个函数返回这个结构体,然后我在JNI的C中需要获取这个结构体里面每个属性的值,并赋值到一个jstring。获取结构体单个属性并转为jstring 这个怎么写啊?
------解决方案--------------------
你要写两个Android.mk 一个是在你的jni下,一个是在第三方源码下:
1\你jni下面的Android.mk:
LOCAL_PATH := $(call my-dir)
include $(CLEAR_VARS)
LOCAL_MODULE := EmvHandler
LOCAL_SRC_FILES := EmvHandler.c
LOCAL_C_INCLUDES := EmvLib_Api.h \
$(LOCAL_PATH)/include/ #这个LOCAL_PATH表示当前Android.mk所在的当前目录,这句话说将当前目录include下的所有.h文件包含进来
LOCAL_SHARED_LIBRARIES := liblog libcutils libthird #libthird 是你要链接的第三方库,暂时取名为 libthird。
LOCAL_LDLIBS +=-L$(LOCAL_PATH) -lm -llog
include $(BUILD_SHARED_LIBRARY)
include $(call all-makefiles-under,$(LOCAL_PATH))
1、你第三方库的Android.mk,这个你可以拿出来使用ndk单独编译,将Android.mk置于代码的顶层目录:
#编译第三方库,这个会生成libthird.so文件,供你的jni链接