我有一个循环,不断从我的串口读取。循环是无限的,所以我知道停止程序的唯一方法是使用Ctrl+C
。这个解决方案的问题,我怀疑也会导致其他问题,当我使用Ctrl+C
时,我的程序突然结束。在程序结束时,我关闭了与我正在访问的串口的文件描述符的连接,但我认为我的程序没有达到那个因为我使用Ctrl+C
命令,这只是停止了准确计划它的位置。
有没有办法让我创建无限的while循环,并在我想要的时候退出,但同时保持执行它下面的代码的能力?
答案 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
当你想退出时。