即使命令可用,Execv也会失败

即使命令可用,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,我知道这是“没有这样的文件或目录”的错误。但我确信文件在那里,因为这是我的路径解析程序在检查所有权限后返回的。 谁能指出我可能犯了什么

我试图在手动搜索程序以执行后调用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)));