程序都是调出来的。

下面我介绍下JNI层的log打印方法的使用,类似与Android sdk提供的log

1、Android 应用层 MainActivity.java

主要功能代码

a)         静态载入 So 库

b)        声明本地方法

c)         调用本地方法

代码附有注释如下:

public class MainActivity extends Activity {

//也就是你mk配置文件中的  LOCAL_MODULE    := NDK_02

private static final String libSoName = "NDK_02";

private Context mContext = null;

private Button btnClick = null;

private String mStrMSG = null;

private EditText etContext = null;

/** Called when the activity is first created. */

@Override

public void onCreate(Bundle savedInstanceState) {

super.onCreate(savedInstanceState);

setContentView(R.layout.main);

mContext = this;

etContext = (EditText)findViewById(R.id.et_content);

btnClick = (Button) findViewById(R.id.btn_click);

btnClick.setOnClickListener(new OnClickListener() {

public void onClick(View v) {

mStrMSG = setParamToJNI(getContent());

if(mStrMSG == null) {

mStrMSG = "调用JNI失败";

}

LogUtils.toastMessage(mContext, mStrMSG);

}

});

}

/**

* 获取输入框内容

* @return 输入框内容

*/

private String getContent() {

String str = etContext.getText().toString();

return str.trim().length() > 0 ? str:"default value";

}

/**

* 该方法为native方法.

*

*    由C实现

*

* @return

*/

public native String  setParamToJNI(String msg);

/**

* 载入JNI生成的so库文件

*/

static {

System.loadLibrary(libSoName);

}

2、Android.mk 文件的配置

之前有介绍过相关的内容,如果对配置有不清晰的地方请阅读 Android.mk 文件 简介

LOCAL_PATH := $(call my-dir)

include $(CLEAR_VARS)

LOCAL_C_INCLUDES := $(LOCAL_PATH)/include

LOCAL_LDLIBS += -L$(SYSROOT)/usr/lib -llog

LOCAL_MODULE    := NDK_02

LOCAL_SRC_FILES := \

PrintLog.c

include $(BUILD_SHARED_LIBRARY)

要打印log 必须添加

LOCAL_LDLIBS += -L$(SYSROOT)/usr/lib -llog

3、JNI层PrintLog.c文件的实现

#include <string.h>

#include <android/log.h>

#include <jni.h>

jstring Java_com_duicky_MainActivity_setParamToJNI(JNIEnv* env, jobject thiz,

jstring msg)

{

if (msg == NULL) {

//该方法为打印的方法

__android_log_print(ANDROID_LOG_INFO, "JNIMsg", "Your params is null");

return (*env)->NewStringUTF(env, "Your params is null");

}

char data[128];

memset(data, 0, sizeof(data));

char *c_msg = NULL;

c_msg = (*env)->GetStringUTFChars(env, msg, 0);

//该方法为打印的方法

__android_log_print(ANDROID_LOG_INFO, "JNIMsg", "Get Param:  %s  From Java", c_msg);

return (*env)->NewStringUTF(env, "success");

}

i、               必须引用头文件#include <android/log.h>

ii、             __android_log_print(ANDROID_LOG_INFO, "JNIMsg", " Log Content ");

JNIMsg 为 你想输出到的过滤标签

Log Content 为你 想输出的相关信息,用法与C的Printf一样

4、运行程序

输入内容

点击发送

查看控制台打印信息

有不理解的兄弟请留言,个人技术有限,有讲错的地方请大牛们指出,讲的不够全面的请多多包涵,谢谢,

点击下载源码 NDK
打印 Log例子

基于 Android NDK 的学习之旅-----JNI LOG 打印的更多相关文章

  1. 基于 Android NDK 的学习之旅-----JNI 数据类型

    经典老套流程,学编程语言东西,先学它最基础的数据类型,JNI也是如此.JNI 定义了一系列基本数据类型和引用数据类型与java想对应. 1.基本数据类型 下面一张表是描述了 Java 基本数据类型和J ...

  2. 【转】基于 Android NDK 的学习之旅-----数据传输(引用数据类型)

    原文网址:http://www.cnblogs.com/luxiaofeng54/archive/2011/08/20/2147086.html 基于 Android NDK 的学习之旅-----数据 ...

  3. 基于 Android NDK 的学习之旅-----环境搭建

    工欲善其事 必先利其器 , 下面介绍下 Eclipse SDK NDK Cygwin CDT 集成开发环境的搭建. 1.Android 开发环境搭建 Android开发环境搭建不是重点,相信看此文章的 ...

  4. 基于 Android NDK 的学习之旅-----序言

    前些日子做了个Android项目, 引擎层 用C的, 准备写这个系类的文章,借此跟朋友来分享下我NDK开放的经验以及自己知识的总结和备忘.希望能给需要这方面资料的朋友提供一定的帮助. 主要涉及到:   ...

  5. 基于 Android NDK 的学习之旅-----Java 调用C

    随便谈谈为什么要Java调用C 吧: 我认为: 1.  有些公司开发Android项目的时候, 许多组件功能可能是C中已经实现了,所以我们没必要同样的功能又在java中实现一遍.例如我之前做的一个项目 ...

  6. 基于 Android NDK 的学习之旅----- C调用Java

    许多成熟的C引擎要移植到Android 平台上使用 , 一般都会 提供 一些接口, 让Android sdk 和 jdk 实现. 下文将会介绍 C 如何 通过 JNI 层调用 Java 的静态和非静态 ...

  7. 基于 Android NDK 的学习之旅-----HelloWorld

    Hello World作为所有编程语言的起始阶段,占据着无法改变的地位,所有中/英/法/德/美……版本的编程教材中,hello world总是作为第一个TEST记录于书本之中,所有的编程第一步就在于此 ...

  8. 基于 Android NDK 的学习之旅-----数据传输(引用数据类型)

    接着上篇文章继续讲.主要关于引用类型的数据传输,本文将介绍字符串传输和自定义对象的传输. 1.主要流程 1.  String 字符串传输 a)         上层定义一个native的方法,需要一个 ...

  9. 基于 Android NDK 的学习之旅-----Android.mk 介绍

    一个Android.mk file用来向编译系统描述你的源代码.具体来说:该文件是GNU Makefile的一小部分,会被编译系统解析一次或多次.你可以在每一个Android.mk file中定义一个 ...

随机推荐

  1. leaf cell

    leaf cell是否可以理解为设计中与或非门等这些基本的单元?

  2. 【Codeforces Round #451 (Div. 2) C】Phone Numbers

    [链接] 我是链接,点我呀:) [题意] 在这里输入题意 [题解] 用map<string,vector > dic;模拟就好. 后缀.翻转一下就变成前缀了. 两重循环剔除这种情况不输出就 ...

  3. Objc执行时读取和写入plist文件遇到的问题

    以下是本猫保持游戏NPC和物件交互的plist文件: 随着游戏和玩家逐步发生互动,玩家会改动人物和物件的交互的状态.这也是RPG游戏最主要的功能. 在切换每一个地图时须要将上一个地图发生的改变存储到p ...

  4. wap.css

    wap.css 一.总结 1.官方有教程:英语的 http://www.developershome.com/wap/wcss/ 2.wap.css :就是控制页面在手机端样式的 3.DOCTYPE ...

  5. 16、cgminer学习之:popen函数和system函数详解(执行系统命令)

    1.popen函数我们先用man指令查一下popen函数: 函数说明: (1)popen()会调用fork()产生子进程,然后从子进程中调用/bin/sh -c来执行参数command的指令. (2) ...

  6. Web应用开发(Servlet+html+Mysql)入门小示例

    在安装好eclipse并配置完安装环境.安装好tomcat的前提下: 1.新建Dynamic Web Project,选择好运行的tomcat服务器版本等:2.在WebContent下:   新建fo ...

  7. VC 常见问题百问

    http://www.cnblogs.com/cy163/archive/2006/06/19/429796.html 经典Vc书 Charles Petzold 的<Programming W ...

  8. 【 Codeforces Round #430 (Div. 2) A 】 Kirill And The Game

    [链接]点击打开链接 [题意] 水题 [题解] 枚举b从x..y看看k*i是不是在l..r之间就好. [错的次数] 0 [反思] 在这了写反思 [代码] #include <cstdio> ...

  9. STL之vector容器的实现框架

    说明:本文仅供学习交流,转载请标明出处,欢迎转载. 实现vector容器的思路等同于实现一个动态数组,以下我们參照源代码的相关资料,给出一个vector容器的大致框架,仅仅有声明,没给出详细的实现. ...

  10. iOS开发RunLoop学习:一:RunLoop简单介绍

    一:RunLoop的简单介绍 #import "ViewController.h" @interface ViewController () @end @implementatio ...