程序都是调出来的。

下面我介绍下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. vue.js提交按钮时简单的if判断表达式示例

    简单的业务需求如下,看图说话 1:当充值金额没有填写的时候,会有Toast小弹框提示"请输入有效的充值金额" if (!this.money) { console.log('mon ...

  2. GraphX 图数据建模和存储

    背景 简单分析一下GraphX是怎么为图数据建模和存储的. 入口 能够看GraphLoader的函数. def edgeListFile( sc: SparkContext, path: String ...

  3. Opera mini for S60 custom server

    Opera mini for S60 custom server 在线改服 http://yourshell.info/mo/mini/ 本人贫穷一族,一直在用S60V2,这种手机启动JAVA很占内存 ...

  4. 动态规划例子:Maximal Square

    Given a 2D binary matrix filled with 0's and 1's, find the largest square containing all 1's and ret ...

  5. Maven学习总结(15)——Maven 项目中pom.xml详解

    <project xmlns="http://maven.apache.org/POM/4.0.0"  xmlns:xsi="http://www.w3.org/2 ...

  6. [RxJS] How To get the results of two HTTP requests made in sequence

    switchMap can chain two HTTP requests together, creating one request based on the results of the fir ...

  7. amazeui学习笔记--css(常用组件15)--CSS动画Animation

    amazeui学习笔记--css(常用组件15)--CSS动画Animation 一.总结 1.css3动画封装:CSS3 动画封装,浏览器需支持 CSS3 动画. Class 描述 .am-anim ...

  8. ajax+客户端与服务器端的交互

    一. AJAX 原生JS var xhr=new XMLHttpRequest(); xhr.open("GET","[请求地址]",false); xhr.o ...

  9. pragma pack,字节对齐

    关于字节对齐 pragma pack 一. 测试代码: // packTest.cpp : Defines the entry point for the console application. / ...

  10. 第三方插件将数据转成json

    1.需要使用第三方jar commons-beanutils-1.7.0.jar /commons-collections-3.1.jar/commons-lang-2.5jar /commons-l ...