繁体   English   中英

为什么在android上重定向stdout / stderr不起作用?

[英]Why is redirecting stdout/stderr on android not working?

我下载了SDL 1.3并在我的Android 2.2设备上与OpenGL ES一起测试了它。 它工作正常,但我没有得到printf调用的输出。 我尝试了android开发者页面中提到的下面的命令,但Eclipse中的DDMSadb 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.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM