有关代码非常庞大,因此我很抱歉我不能在这里发布。问题是: - 我写了一个小程序如下:
#include<stdio.h>
#include<sys/types.h>
#include<unistd.h>
#include<signal.h>
int main()
{
printf("\n Process id",getpid());
fflush(stdout);
if(kill(getpid(),SIGSTOP)!=0)
printf("\nError");
}
运行后,我得到以下o / p:
流程ID 2664
[1] +停止了./test_SIGSTOP
[目录路径] $
这正是预期的结果。但在我的实际程序中,我说非常庞大...控制来到kill调用之上(我知道它,因为我有打印语句并fflushed它们)并挂起而不会自动停止进程和命令提示符的出现。 非常感谢指针。 感谢
答案 0 :(得分:1)
您可以将调试器附加到正在运行的程序,并找出它挂起的位置/原因。此外,raise()
功能使用起来更方便。但首先,使用ps并检查进程的标志以确认其状态(运行/休眠/停止)。