Android重定向文件代码编写,Android,CMDTool,stdout重定向,“致命信号11(SIGSEGV)”...

用例

Android C命令行工具lunching“/ system / bin / getprop”并将其stdout重定向到套接字

问题

启动'getprop'失败,出现“F / libc(20694):致命信号11(SIGSEGV),代码1,故障地址0x0,tid 20694(getprop)”,代码和logcat片段如下 .

为什么我会收到SIGSEGV?为什么分叉过程失败?

实施

HRESULT ServiceCore::CreateProcessAndRedirectStdout(IN char* pCmd, IN char** args, OUT SOCKET& stdoutstream) {

HRESULT hr = S_OK;

int fds[2] = { 0 };

pid_t pid = 0;

stdoutstream = 0;

if (SOCKET_ERROR == socketpair(PF_UNIX, SOCK_STREAM, 0, fds))

goto ErrExit;

stdoutstream = fds[1];

if((pid = fork()) < 0)

goto ErrExit;

if (pid == 0) {

// The newly created process

__android_log_print(ANDROID_LOG_INFO, "ServiceCore", "CreateProcessAndRedirectStdout>> '%s' started", pCmd);

int newfd = dup2(fds[0], STDOUT_FILENO);

__android_log_print(ANDROID_LOG_INFO, "ServiceCore", "CreateProcessAndRedirectStdout>> '%s' newfd:%d, oldfd:%d", pCmd, newfd, fds[0]);

_ASSERT(newfd == STDOUT_FILENO);

close(fds[0]);

close(fds[1]);

execvp(pCmd, args);

__android_log_print(ANDROID_LOG_INFO, "ServiceCore", "CreateProcessAndRedirectStdout>> '%s' FAILED", pCmd);

exit(1);

}

__android_log_print(ANDROID_LOG_INFO, "ServiceCore", "CreateProcessAndRedirectStdout>> '%s(%d)' Created", pCmd, pid);

return S_OK;

ErrExit:

if (0 != pid)

kill(pid, SIGTERM);

close(fds[0]);

close(fds[1]);

stdoutstream = 0;

return hr;

}

...

char* args[] = { 0 };

SOCKET soc;

if (SUCCEEDED(hr = CreateProcessAndRedirectStdout("/system/bin/getprop", args, soc))) {

errno = 0;

__android_log_print(ANDROID_LOG_INFO, "ServiceCore", "SendConfig>> Reading props");

char pTmp[256000];

int iRet = read(soc, pTmp, sizeof(pTmp));// Read the first few lines

}

...

logcat

I/ServiceCore(20689): CreateProcessAndRedirectStdout>> '/system/bin/getprop(20694)' Created

I/ServiceCore(20689): SendConfig>> Reading props

I/ServiceCore(20694): CreateProcessAndRedirectStdout>> '/system/bin/getprop' started

I/ServiceCore(20694): CreateProcessAndRedirectStdout>> '/system/bin/getprop' newfd:1, oldfd:10

F/libc (20694): Fatal signal 11 (SIGSEGV), code 1, fault addr 0x0 in tid 20694 (getprop)

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
sys.stdout重定向是指将标准输出重定向到其他输出流,例如文件或者内存缓冲区。这样做可以将程序输出保存到文件中或者进行其他处理。在Python中,可以使用sys.stdout来访问标准输出流,并通过重定向来改变其目标。 下面是一个示例,展示了如何将标准输出重定向文件中: ```python import sys # 保存原始的sys.stdout original_stdout = sys.stdout # 打开文件来作为新的输出目标 with open('output.txt', 'w') as f: # 将sys.stdout重定向文件 sys.stdout = f # 这里的print语句将会写入文件而不是控制台 print('Hello, World!') # 恢复原始的sys.stdout sys.stdout = original_stdout ``` 封装是指将一段代码或功能包装成一个独立的模块、类或函数,以便在其他地方重复使用。封装可以提高代码的可维护性和可复用性。 在Python中,可以使用类来封装一组相关的功能。下面是一个简单的示例,展示了如何使用类来封装一些功能: ```python class Calculator: def __init__(self): self.result = 0 def add(self, num1, num2): self.result = num1 + num2 def multiply(self, num1, num2): self.result = num1 * num2 def get_result(self): return self.result # 使用Calculator类进行计算 calc = Calculator() calc.add(2, 3) print('Result:', calc.get_result()) # 输出: Result: 5 calc.multiply(4, 5) print('Result:', calc.get_result()) # 输出: Result: 20 ``` 在这个示例中,Calculator类封装了加法和乘法功能,并提供了get_result方法来获取计算结果。这样,我们可以在其他地方使用Calculator类来进行计算,而无需重复编写加法和乘法的实现代码

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值