
1.while (1) {
2. char *cmd = read_command();
3. int child_pID = fork();
4. if (child_pID == 0) {
5. exec(cmd);
6. }else {
7. waitpID(child_pID);
8. }
9.}
因此,如果我们在shell中运行’exec ls’,cmd就是一个’exec ls’字符串.子进程在第3行分叉.在第5行中,exec(cmd)将替换子进程,但不会影响父进程.如果父进程不受影响,为什么终端会关闭呢?
请告诉我上面的推理中的缺陷.
解决方法 如果你运行ls,你的shell进程将启动另一个运行ls程序的进程,然后它将等待它完成.完成后,控制权返回给shell.使用exec ls,你实际上用ls程序替换当前进程中的shell程序,这样当它完成时,没有shell等待它.
最有可能的是,您将有一个终端程序或init作为父进程,这将是您的进程退出时将接管的内容.这就是你的shell消失的原因,因为你明确告诉它.
有关shell / ls(非执行)情况的说明,请参见this answer.
至于你的更新,shell并不总是创建一个单独的进程来做东西.有很多内部命令(如cd或别名)不涉及制作其他进程(当然这取决于你的shell,但是,作为一个例子,你可以通过输入man bash-builtins看到bash内部命令在命令提示符下).
exec就是其中之一.它只是用您指定的程序替换shell本身(即,不是分叉的子进程).这就是为什么它不按你的想法行事.
总结以上是内存溢出为你收集整理的linux – 如果你在shell中运行’exec ls’会发生什么?为什么?全部内容,希望文章能够帮你解决linux – 如果你在shell中运行’exec ls’会发生什么?为什么?所遇到的程序开发问题。
如果觉得内存溢出网站内容还不错,欢迎将内存溢出网站推荐给程序员好友。
欢迎分享,转载请注明来源:内存溢出
微信扫一扫
支付宝扫一扫
评论列表(0条)