在C中留下无限循环

时间:2012-10-22 11:29:34

标签: c while-loop

我有一个循环,不断从我的串口读取。循环是无限的,所以我知道停止程序的唯一方法是使用Ctrl+C。这个解决方案的问题,我怀疑也会导致其他问题,当我使用Ctrl+C时,我的程序突然结束。在程序结束时,我关闭了与我正在访问的串口的文件描述符的连接,但我认为我的程序没有达到那个因为我使用Ctrl+C命令,这只是停止了准确计划它的位置。

有没有办法让我创建无限的while循环,并在我想要的时候退出,但同时保持执行它下面的代码的能力?

5 个答案:

答案 0 :(得分:10)

试试这个,看看会发生什么:

#include <unistd.h>
#include <stdio.h>
#include <signal.h>

volatile sig_atomic_t stop;

void
inthand(int signum)
{
    stop = 1;
}

int
main(int argc, char **argv)
{
    signal(SIGINT, inthand);

    while (!stop)
        pause();
    printf("exiting safely\n");

    return 0;
}

Ctrl-C向您的进程发送信号(SIGINT)。该过程的默认操作是在获取时退出,但您可以捕获信号并优雅地处理它。

答案 1 :(得分:7)

你可以这样做:

sig_atomic_t volatile g_running = TRUE;

void sig_handler(int signum)
{
  if (signum == SIGINT)
    g_running = FALSE;
}

int main()
{
  signal(SIGINT, &sig_handler);
  while (g_running)
  {
    //your code
  }
  //cleanup code
}

这将捕获按CTRL-C生成的SIGINT信号,并通过将g_running设置为FALSE来中断循环。然后执行清理代码

答案 2 :(得分:0)

使用控制while循环的变量,例如while(running)。只需将此变量异步设置为false即可退出循环。

示例:

volatile int running = 1;
while(running) {
    /* Your code */
}

所以另一个代码,比方说回调函数,就是这个

running = 0;

您可以将此回调设置为拦截SIG_TERM(默认情况下为Ctrl-C)或您选择的任何信号(SIG_KILL除外,它不会发送到进程)。

答案 3 :(得分:0)

而不是无限的while循环,创建一个while循环,它监听/读取特定文件中的boolean值。您可以编辑该文件以退出循环。

答案 4 :(得分:0)

使用ctrl + C实际上会中断您的程序。为了避免这种情况

1)使用变量并在每次循环迭代中检查其状态。

int  shouldExit  = 0;

----
----
---
while (your_condition){
  if(shouldExit == 1) {
     break;
  }

  // Your loop logic here
}

然后异步设置变量

shouldExit = 1 

当你想退出时。