from: http://www.cnblogs.com/Franck/p/3593884.html

Android如何打印std::cout/printf(重定向stdout)

Android应用调试时没有stdout和stderr的输出,网上看到的解释都是下面这个样子:

#################################################

Android系统在默认情况下,将stdout和stderr(Java中的System.out 和 System.err)重定向到/dev/null。

如果一个进程运行了 Dalvik VM,那么就可以把上面两个输出拷贝到日志文件中去,这种情况下,系统会把stdout

和stderr输出到标签为“stdout”和“stderr”的日志中。

具体做法如下:

$ adb shell stop

$ adb shell setprop log.redirect-stdio true

$ adb shell start

(以上命令执行之后立即生效,不过,如果重启手机,则上面的设置就消失了。

可以在 /data/local.prop 文件中加入命令,从而无需重新执行以上命令。)

##################################################

经过实验,这个方法可以输出JAVA代码中的System.out/err。但是现在很多应用为了跨平台用C/C++开发(特别是游戏,我调试的也是游戏),C/C++中的std::cout/printf用这种方法并不能输出,网上有些解释说需要先root设备($adb root),再执行上面的语句。由于我的情况不允许root,所以就没有验证。

继续网上搜索资料,发现一个方法:

freopen函数。

这个函数是用来重定向的,具体用法可以可以自行google。

我在我项目C/C++代码执行的入口地方加入了下面代码:

freopen("/sdcard/tmp/loglog.txt", "w", stdout);

重新编译执行,所有std::cout/printf的输出都输出到了指定文件中。需要注意的是:参数一指定的路径必须是存在的,而且必须有这个路径的写权限。否则,这个代码“没有任何效果”。

这个方法很好解决了我的问题,特此记录一下。

更多相关文章

  1. Linux 环境下实战 Rsync 备份工具及配置 rsync+inotify 实时同步
  2. 获取apk签名信息
  3. 在Android应用中实现Google搜索的例子
  4. Android(安卓)手绘 - 支持保存为图片
  5. Cocos2D-HTML5 Android项目编译
  6. Android(安卓)重读官方文档 4 SharedPreferences
  7. 【Android(安卓)开发教程】Activity的生命周期
  8. Android(安卓)屏幕旋转操作Demo
  9. 三行代码实现白天夜间模式流畅切换的实现库

随机推荐

  1. Android(安卓)java层音频相关的分析与理
  2. 清洁和新Android架构的认知诉求
  3. android项目目录介绍之二
  4. 【翻译】Android(安卓)数据存储
  5. Android调用安卓自带摄像头API开启双摄
  6. Android(安卓)SAX解析XML
  7. Android应用反编译
  8. Android(安卓)N 程序适配要点
  9. Android中的搜索(search)概述
  10. Android--Handler的使用方法:在子线程中更