gpt4 book ai didi

android - 如何查看在 Android 的 init.rc 中启动的 shell 脚本的调试输出?

转载 作者:行者123 更新时间:2023-12-04 18:05:20 30 4
gpt4 key购买 nike

我创建了一个 shell 脚本 test.sh,它在 Android 的 init.rc 中作为服务运行。脚本运行,但如果我尝试回显任何内容,我在控制台中看不到任何输出。我可以使用 init.rc 编写调试输出:

编写/dev/kmsg“运行测试脚本”

但是如果我做一个

echo "测试输出"

在 test.sh 中,我在控制台或 logcat 中看不到任何内容。

有什么想法吗?

谢谢

马龙

编辑:这是我正在测试的脚本:

#!/system/bin/sh 
echo "Testing!"

以及init.rc中的相关行:

chown system system /data/test.sh
chmod 0774 /data/test.sh

# Periodic service test
service periodic_test /data/test.sh
class main

最佳答案

当它们的stdout 被重定向到/dev/null forks 进程在init.xxx.rc 文件中指定的服务strong> 所以你不会在控制台上看到你的调试打印。

请注意控制台和 logcat 是正交的,即使在 init 进程未调用的普通 shell 脚本中,echo "bla"也不会反射(reflect)在 logcat 中。

可能的跟踪方法与您对 dmesg 所做的一样,或者使用与 logcat 接口(interface)的 native 代码(从脚本中调用)

关于android - 如何查看在 Android 的 init.rc 中启动的 shell 脚本的调试输出?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/27951055/

30 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com