c - execvp 返回后,为什么我的程序没有从中断的地方继续?

标签 c multithreading execvp

我有这样一段代码作为子线程运行:

if(someVar == 1){
doSomeStuff;

_exit(0)
}
else
   execvp(*(temp->_arguments), temp->_arguments);
printf("I'm done\n");

当我使用 someVar == 1 运行程序时,我知道 _exit(0) 调用终止了我的线程。但是,当它设置为 0 时,为什么程序在 execvp() 调用后不继续执行 printf 语句?

最佳答案

如果你exec* (调用 exec 系列中的任何 exec 函数),然后将新程序的代码加载到您当前的进程中,并继续执行其主要功能及其内容。成功执行这些函数后,它们将永远不会返回,因为您的 printf 不再存在于内存中。

我认为您将 exec*fork 混淆了功能。这将拼接出一个新的子进程,该子进程将运行与父进程相同的代码。

如果你想要创建一个新线程,与主线程共享数据和地址空间,你应该使用pthread_create功能。新进程不会共享数据,您必须使用其他机制(如管道或共享内存)与其他进程通信。

关于c - execvp 返回后,为什么我的程序没有从中断的地方继续?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/658431/

相关文章:

c# - 如何使用 Task 设置最大并发线程数

c - execvp 的错误地址错误

c - 如何查找给定文件是符号(软)链接还是硬链接(hard link)

c - fclose 导致 exc_bad_access

c# - 有一组任务,一次只运行 X

C++ exec 执行的 bash 脚本随机停止

c - 如何在 C 中执行 ls *.txt

c - 这两个 C 声明之间有什么区别?

c - 链表插入中的 strcmp 导致程序崩溃

c++ - 在 boost 线程中读取标志