Android APP调用shell命令 stderr输出大量日志信息就会阻塞?

在将嵌入式Linux软件移植到Android环境中时,发现通过Android APP调用程序时会出现阻塞现象,而在adb shell中则正常运行。经过排查发现关闭日志输出后问题解决,计划进一步通过实验验证。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

遇到一个很奇怪的现象,移植嵌入式Linux的一个软件到Android中,把对应的嵌入式下的so库文件也都拷贝到/lib目录下了,在adb shell命令行里执行这个程序没有任何问题,有一点是输出的stderr的日志信息比较多,但是完全没有影响到程序的运行结果。但是如果在Android APP里调root命令运行这个程序,那么就会卡住,使用strace -p xxx(xxx为进程pid),查看卡到一行日志输出了。

想了想,是不是日志输出过多,在App里调用时多少出现的问题呢?毕竟在adb shell中完全是没有问题的。最后将日志输出的开关关闭,App里调用正常了。这着实很奇怪,又让我对操作系统进一步深入了解了。

这个事不想到此为止,我还要把这个问题确认下来,写一个C程序,使用arm-linux-gcc静态编译,C程序连续输出大量的log到stderr中,然后使用App调用该程序,看是否同样会阻塞,这样这个事能彻底定稿。但是这会儿没有时间测试了,先把这个TODO写下来。

这里写图片描述

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

袁保康

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值