一步一步学习androidNDK编程(log调试和解决中文乱码)

           上一篇说到了androidNDK编程的helloworld,今天,学习了如何在ndk开发时候,在c代码当中,向java代码那样,打印出log  

1. 我们需要引入头文件:

#include <android/log.h>

2.定义打印的tag,这里相当于java中的static final类型

#define LOG_TAG "onEvent"

3.定义宏,相当于声明一个方法:

#define LOGD(fmt, args...) __android_log_print(ANDROID_LOG_INFO, LOG_TAG, fmt, ##args)

4.在c代码中使用:

LOGD("我是需要被打印的字符串");


        经过以上四步,我们就可以像在java代码中那样,打印log了,并且,我们这里声明的tag为"onEvent",因此同样可以通过"adb logcat | grep -n "onEvent"" ,这样的命令来过滤查询。



        下面如何解决中文乱码的问题:

        如果我在c代码中返回这样一个字符串:return (*env)->NewStringUTF(env,"hello world 我是中国人");    这样做是有可能存在乱码情况的,那么如何解决的呢,其实很简单,只需要将该android工程和对应的.c文件编码方式同时设置为utf-8格式即可。

        这里需要注意的一点是,如果是在早期的ndk版本中,我们需要这么写:

        1.首先调用声明的native方法,得到c代码汇总返回的字符串

           String tempStr = helloWorldNdk();

        2.通过以下代码来实现编码的转换:

        try {
new String(tempStr.getBytes("iso-8859-1"),"utf-8");

} catch (UnsupportedEncodingException e) {
e.printStackTrace();
}


  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值