基于 Android NDK 的学习之旅-----JNI LOG 打印
程序都是调出来的。
下面我介绍下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 打印的更多相关文章
- 基于 Android NDK 的学习之旅-----JNI 数据类型
经典老套流程,学编程语言东西,先学它最基础的数据类型,JNI也是如此.JNI 定义了一系列基本数据类型和引用数据类型与java想对应. 1.基本数据类型 下面一张表是描述了 Java 基本数据类型和J ...
- 【转】基于 Android NDK 的学习之旅-----数据传输(引用数据类型)
原文网址:http://www.cnblogs.com/luxiaofeng54/archive/2011/08/20/2147086.html 基于 Android NDK 的学习之旅-----数据 ...
- 基于 Android NDK 的学习之旅-----环境搭建
工欲善其事 必先利其器 , 下面介绍下 Eclipse SDK NDK Cygwin CDT 集成开发环境的搭建. 1.Android 开发环境搭建 Android开发环境搭建不是重点,相信看此文章的 ...
- 基于 Android NDK 的学习之旅-----序言
前些日子做了个Android项目, 引擎层 用C的, 准备写这个系类的文章,借此跟朋友来分享下我NDK开放的经验以及自己知识的总结和备忘.希望能给需要这方面资料的朋友提供一定的帮助. 主要涉及到: ...
- 基于 Android NDK 的学习之旅-----Java 调用C
随便谈谈为什么要Java调用C 吧: 我认为: 1. 有些公司开发Android项目的时候, 许多组件功能可能是C中已经实现了,所以我们没必要同样的功能又在java中实现一遍.例如我之前做的一个项目 ...
- 基于 Android NDK 的学习之旅----- C调用Java
许多成熟的C引擎要移植到Android 平台上使用 , 一般都会 提供 一些接口, 让Android sdk 和 jdk 实现. 下文将会介绍 C 如何 通过 JNI 层调用 Java 的静态和非静态 ...
- 基于 Android NDK 的学习之旅-----HelloWorld
Hello World作为所有编程语言的起始阶段,占据着无法改变的地位,所有中/英/法/德/美……版本的编程教材中,hello world总是作为第一个TEST记录于书本之中,所有的编程第一步就在于此 ...
- 基于 Android NDK 的学习之旅-----数据传输(引用数据类型)
接着上篇文章继续讲.主要关于引用类型的数据传输,本文将介绍字符串传输和自定义对象的传输. 1.主要流程 1. String 字符串传输 a) 上层定义一个native的方法,需要一个 ...
- 基于 Android NDK 的学习之旅-----Android.mk 介绍
一个Android.mk file用来向编译系统描述你的源代码.具体来说:该文件是GNU Makefile的一小部分,会被编译系统解析一次或多次.你可以在每一个Android.mk file中定义一个 ...
随机推荐
- leaf cell
leaf cell是否可以理解为设计中与或非门等这些基本的单元?
- 【Codeforces Round #451 (Div. 2) C】Phone Numbers
[链接] 我是链接,点我呀:) [题意] 在这里输入题意 [题解] 用map<string,vector > dic;模拟就好. 后缀.翻转一下就变成前缀了. 两重循环剔除这种情况不输出就 ...
- Objc执行时读取和写入plist文件遇到的问题
以下是本猫保持游戏NPC和物件交互的plist文件: 随着游戏和玩家逐步发生互动,玩家会改动人物和物件的交互的状态.这也是RPG游戏最主要的功能. 在切换每一个地图时须要将上一个地图发生的改变存储到p ...
- wap.css
wap.css 一.总结 1.官方有教程:英语的 http://www.developershome.com/wap/wcss/ 2.wap.css :就是控制页面在手机端样式的 3.DOCTYPE ...
- 16、cgminer学习之:popen函数和system函数详解(执行系统命令)
1.popen函数我们先用man指令查一下popen函数: 函数说明: (1)popen()会调用fork()产生子进程,然后从子进程中调用/bin/sh -c来执行参数command的指令. (2) ...
- Web应用开发(Servlet+html+Mysql)入门小示例
在安装好eclipse并配置完安装环境.安装好tomcat的前提下: 1.新建Dynamic Web Project,选择好运行的tomcat服务器版本等:2.在WebContent下: 新建fo ...
- VC 常见问题百问
http://www.cnblogs.com/cy163/archive/2006/06/19/429796.html 经典Vc书 Charles Petzold 的<Programming W ...
- 【 Codeforces Round #430 (Div. 2) A 】 Kirill And The Game
[链接]点击打开链接 [题意] 水题 [题解] 枚举b从x..y看看k*i是不是在l..r之间就好. [错的次数] 0 [反思] 在这了写反思 [代码] #include <cstdio> ...
- STL之vector容器的实现框架
说明:本文仅供学习交流,转载请标明出处,欢迎转载. 实现vector容器的思路等同于实现一个动态数组,以下我们參照源代码的相关资料,给出一个vector容器的大致框架,仅仅有声明,没给出详细的实现. ...
- iOS开发RunLoop学习:一:RunLoop简单介绍
一:RunLoop的简单介绍 #import "ViewController.h" @interface ViewController () @end @implementatio ...