即使命令可用,Execv也会失败
我试图在手动搜索程序以执行后调用execv 就我而言, c是一个结构,它将参数作为字符串数组,在接收输入时传递参数。nargs是参数的数量。 c->args[0]将包含“ls”、“cat”等 我尝试在我的子进程中打印args[0]、fullPath等的值。它们都显示“/bin/ls”、“/bin/cat”等值。但是当我调用execv时,它返回-1,errno为2,我知道这是“没有这样的文件或目录”的错误。但我确信文件在那里,因为这是我的路径解析程序在检查所有权限后返回的。 谁能指出我可能犯了什么错误 //发生在孩子身上的部分即使命令可用,Execv也会失败,c,fork,execv,C,Fork,Execv,我试图在手动搜索程序以执行后调用execv 就我而言, c是一个结构,它将参数作为字符串数组,在接收输入时传递参数。nargs是参数的数量。 c->args[0]将包含“ls”、“cat”等 我尝试在我的子进程中打印args[0]、fullPath等的值。它们都显示“/bin/ls”、“/bin/cat”等值。但是当我调用execv时,它返回-1,errno为2,我知道这是“没有这样的文件或目录”的错误。但我确信文件在那里,因为这是我的路径解析程序在检查所有权限后返回的。 谁能指出我可能犯了什么
char *fullPath = PathResolver(c->args[0],1,&permission);
printf("FullPath: %s -- Permission: %d\n",fullPath,permission);
if(permission==0)
{
fprintf(stderr, "%s: Command not found\n",c->args[0]);
}
else if(permission==-1)
{
fprintf(stderr, "%s: Permission denied\n",c->args[0]);
}
else
{
char* args[c->nargs+1];
int m=0;
for(m=0;m<c->nargs;m++)
{
strcpy(args[m],c->args[m]);
}
args[c->nargs] = NULL;
printf("%d\n",execv(args[0], args));
printf("errno: %d\n",errno);
}
}strcpy(args[m],c->args[m])
是未定义的行为,因为args[m]
不是有效内存的指针
以下内容可能更简单:
char * args[c->nargs + 1];
for (size_t m = 0; m != c->nargs; ++m)
{
args[m] = c->args[m];
}
args[c->nargs] = NULL;
不需要复制字符串
(这可能不是您的实际问题,但它肯定会阻止您的程序正确运行。)execv()
希望程序名的前缀是完整路径作为第一个参数
要搜索路径而不是提供路径,请使用execvp()
更新: 还有这条线
returnString = malloc((sizeof(char)));
只将
1
字节分配给returnString
,这对于如何使用returnString
来说是非常少的,但我仍然能够打印args[m]的值并确认它是正确的值。也许,我很幸运。无论如何,我都会实施它。我还尝试直接传递c->args[0],但这也不起作用。这就是为什么我认为我将重复字符串数组并尝试。无论如何,这是有用的。我会检查它的,例如,它必须是像“/bin/ls”这样的东西,对吗?这就是我从PathResolver函数得到的,并将其指定为第一个参数。但是它不起作用。@鱼雷:我看不出你在哪里分配给args
其他任何东西,然后从c->args
中分配值。
returnString = malloc((sizeof(char)));