![](/img/trans.png)
[英]Android equivalent of “/dev/stdout” and “/dev/stderr”
[英]Why is redirecting stdout/stderr on android not working?
我下载了SDL 1.3并在我的Android 2.2设备上与OpenGL ES一起测试了它。 它工作正常,但我没有得到printf
调用的输出。 我尝试了android开发者页面中提到的下面的命令,但Eclipse中的DDMS
和adb logcat
都没有报告程序使用printf
写入的字符串。 我确保过滤stdout
标签。
$ adb shell stop
$ adb shell setprop log.redirect-stdio true
$ adb shell start
我错过了什么或做错了什么?
根据这个演示文稿 , log.redirect-stdio
用于Dalvik输出,为了重定向C / C ++输出(例如printf
),你必须在设备上安装busybox并使用它的xargs
实用程序,如下所示:
myprogram | xargs log
这显然适用于作为独立可执行文件调用的代码。 如果它仅用于调试目的,您可以编写一个小程序来调用您的库并使用xargs
从您的应用程序调用它。
另一种方法是使用文件/data/local.prop
,只包含log.redirect-stdio=true
。 也许这效果更好? 另外,请注意stdout是缓冲的,因此可能是您的输出仍然位于缓冲区中,等待刷新。 您可以手动调用fflush
进行检查。
声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.