我有这样一段代码作为子线程运行:
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/