程序在 execvp(command.argv[0], command.argv) 后停止 [英] program stops after execvp( command.argv[0], command.argv)

查看:26
本文介绍了程序在 execvp(command.argv[0], command.argv) 后停止的处理方法,对大家解决问题具有一定的参考价值,需要的朋友们下面随着小编来一起学习吧!

问题描述

我正在编写一个小 shell 程序,它接受一个命令并执行它.如果用户输入了无效命令,则 if 语句返回 -1.如果命令是正确的,它就会执行命令,但是一旦它执行了命令,程序就会结束.我做错了什么是不执行它之后的代码行?我已经用 ls 和 cat 命令测试了 execvp(command.argv[0], command.argv),所以我很确定它可以工作.这是我的代码.

I am writing a small shell program that takes a command and executes it. If the user enters a not valid command the if statement returns a -1. If the command is correct it executes the command, however once it executes the command the program ends. What am I doing wrong that is does not execute the lines of code after it? I have tested execvp( command.argv[0], command.argv) with ls and cat commands so I am pretty sure it works. Here is my code.

  int shell(char *cmd_str ){
  int commandLength=0;
  cmd_t command;
  commandLength=make_cmd(cmd_str,  command);
  cout<< commandLength<<endl;
  cout << command.argv[0]<< endl;
  if( execvp( command.argv[0], command.argv)==-1)
//if the command it executed nothing runs after this line
  {
    commandLength=-1;

}else
{
  cout<<"work"<<endl;
}

  cout<< commandLength<<endl;
   return commandLength;


}

推荐答案

来自 手册页 execvp(3)

exec() 系列函数将当前进程映像替换为一个新的过程映像

The exec() family of functions replaces the current process image with a new process image

因此,您当前的进程映像将被您的命令映像覆盖!因此,您需要始终使用 fork+exec 组合,以便您的命令在子进程中执行,并且您当前的进程作为父进程安全地继续!

So your current process image is overwritten with the image of your command! Hence you need to use a fork+exec combination always so that your command executes in the child process and your current process continues safely as a parent!

我想用一张图片来说明问题,因为一张图片能说出一千个单词.无意冒犯:) :)

On a lighter note I want to illustrate the problem with a picture as a picture speaks a thousand words. No offence intended :) :)

这篇关于程序在 execvp(command.argv[0], command.argv) 后停止的文章就介绍到这了,希望我们推荐的答案对大家有所帮助,也希望大家多多支持IT屋!

查看全文
登录 关闭
扫码关注1秒登录
发送“验证码”获取 | 15天全站免登陆