这个问题的表面现象是用system 调用的方式执行udhcpc 会失败。解释:由于system 是
通过fork 实现的,而子进程会复制父进程的VM 空间,当父进程占用较多VM 空间,
很容易导致system 调用失败。其本质是子进程分配VM 空间失败导致的。解决方法:
执行一下:
echo 1 > /proc/sys/vm/overcommit_memory
即可。
更好的解决办法是不使用system 调用方法,而是使用posix_spawn 调用,简单的示
例如下:
#include <stdio.h>
#include <stdlib.h>
#include <sys/types.h>
#include <unistd.h>
#include <spawn.h>
#include <sys/wait.h>
int main(int argc, char* argv[])
{
pid_t pid;
int err;
char *spawnedArgs[] = {"/bin/ls","-l","/home ",NULL};/* posix_spawn需要指
定子进程的命令的全路径(绝对路径) */
char *spawnedEnv[] = {NULL};
printf("Parent process id=%ld\n", getpid());
if((err=posix_spawn(&pid, spawnedArgs[0], NULL, NULL, spawnedArgs, spawnedEnv)) !=0 )
{
fprintf(stderr,"posix_spawn() error=%d\n",err), exit(-1);
}
printf("Child process id=%ld\n", pid);
/* Wait for the spawned process to exit */
(void)wait(NULL);
return 0;
}
posix_spawn 的更多用法,请自行上网搜索。
本文探讨了system调用执行失败的原因,通常由于子进程复制父进程的VM空间过多导致。提供了修改overcommit_memory参数的临时解决方案,并推荐使用posix_spawn替代system调用,附带示例代码说明。
1559

被折叠的 条评论
为什么被折叠?



