当前位置:首页 > 嵌入式 > 嵌入式软件
[导读] 一、mk文件的结构骨架这里的骨架,就是指我们一般需要写的几个重要的语句和模块。还是采用Hello Jni的mk文件: 1 LOCAL_PATH := $(ca

 一、mk文件的结构骨架

这里的骨架,就是指我们一般需要写的几个重要的语句和模块。还是采用Hello Jni的mk文件:

1 LOCAL_PATH := $(call my-dir)
[!--empirenews.page--]
2 include $(CLEAR_VARS)
3 LOCAL_MODULE    := HelloJni
[!--empirenews.page--]
4 LOCAL_SRC_FILES := HelloJni.c
5 include $(BUILD_SHARED_LIBRARY)
[!--empirenews.page--]

简单的5句话。

1. LOCAL_PATH := $(call my-dir) 。

一个 Android.mk 文件 首先必须定义好 LOCAL_PATH 变量。它用于在开发树中查找源文件。在这个例子中,宏函数’my-dir’, 由编译系统提供,用于返回当前路径(即包含 Android.mk 文件的目录)。

2. include $(CLEAR_VARS)。

CLEAR_VARS 由编译系统提供,指定让 GNU MAKEFILE 为你清除许多 LOCAL_XXX 变量(例如 LOCAL_MODULE, LOCAL_SRC_FILES, LOCAL_STATIC_LIBRARIES, 等等 ...), 除 LOCAL_PATH 。这是必要的,因为所有的编译控制文件都在同一个 GNU MAKE 执行环境中,所有的变量都是全局的。

3. LOCAL_MODULE := HelloJni。

LOCAL_MODULE变量必须定义,以标识你在Android.mk文件中描述的每个模块。名称必须是唯一的,而且不包含任何空格。注意编译系统会自动产生合适的前缀和后缀,换句话说,一个被命名为‘HcSyncml‘的共享库模块,将会生成‘libHelloJni.so‘文件。

4. LOCAL_SRC_FILES := HelloJni.c

LOCAL_SRC_FILES中加入源文件路径(需要编译的文件),多个文件用 ‘ ’ 隔开,如果要换行,用‘’+ 回车换行。

5. include $(BUILD_SHARED_LIBRARY)

表示生成一个共享库,其他的还有BUILD_STATIC_LIBRARY(这个表示生成一个静态库)。

二、在Jni中打日志LOG

在Jni中打日志(还是以Hello Jni为例),

1. 需要mk文件中再加入一条语句:

1 LOCAL_LDLIBS    := -llog
[!--empirenews.page--]

2.HelloJni.c文件中,加入头文件和函数声明。最终文件如下:

01 #include <stdio.h>
02 #include <android/log.h>
[!--empirenews.page--]
03 #include "HelloJni.h"
04  
[!--empirenews.page--]
05 #define  LOG_TAG    "HelloJni"
06 #define  LOGI(...)  __android_log_print(ANDROID_LOG_INFO,LOG_TAG,__VA_ARGS__)
[!--empirenews.page--]
07 #define  LOGE(...)  __android_log_print(ANDROID_LOG_ERROR,LOG_TAG,__VA_ARGS__)
08  
[!--empirenews.page--]
09 jstring Java_com_example_hellojni_MainActivity_getHelloJniString
10   (JNIEnv * env, jobject clazz)
[!--empirenews.page--]
11 {
12     LOGI("call from jni!");
[!--empirenews.page--]
13     return (*env)->NewStringUTF(env, "Hello Jni!");
[!--empirenews.page--]
14 }

除了ANDROID_LOG_INFO这个日志级别,还有如下的:

1 ANDROID_LOG_UNKNOWN
[!--empirenews.page--]
2 ANDROID_LOG_DEFAULT
3 ANDROID_LOG_VERBOSE
[!--empirenews.page--]
4 ANDROID_LOG_DEBUG
5 ANDROID_LOG_INFO
[!--empirenews.page--]
6 ANDROID_LOG_WARN
7 ANDROID_LOG_ERROR
[!--empirenews.page--]
8 ANDROID_LOG_FATAL
9 ANDROID_LOG_SILENT
[!--empirenews.page--]

3.编译so文件,运行程序吧!奇迹出现啦!

4.LOGI除了直接输出字符串,也可以用占位符的方式显示。例如

LOGI(%s,"call from jni!");

本站声明: 本文章由作者或相关机构授权发布,目的在于传递更多信息,并不代表本站赞同其观点,本站亦不保证或承诺内容真实性等。需要转载请联系该专栏作者,如若文章内容侵犯您的权益,请及时联系本站删除( 邮箱:macysun@21ic.com )。
换一批
延伸阅读
关闭