linux中关于线程终止的问题

发布于 2022-10-15 05:41:56 字数 2892 浏览 15 评论 0

本帖最后由 caffee_1989 于 2011-05-30 16:19 编辑

我想在主程序中退出时把线程也终止了,有什么办法?
线程中是读串口read(),不退出好像会造成堵塞。
代码如下:

#include <sys/types.h>
#include <sys/stat.h>
#include <fcntl.h>
#include <termios.h>
#include <stdio.h>
#include <strings.h>
#include <errno.h>
#include <unistd.h>
#include <stdio.h>
#include <stdlib.h>
#include <sys/ioctl.h>
#include <pthread.h>
#include <signal.h>

#define BAUDRATE B115200            
#define MODEMDEVICE "/dev/ttySAC0"
#define _POSIX_SOURCE 1

#define FALSE 0
#define TRUE 1

volatile int STOP=FALSE;
static int QUIT=FALSE;

void *myThread(void)
{
    int fd,res;
    struct termios oldtio,newtio;
    char buf[255];
    fd = open(MODEMDEVICE, O_RDWR | O_NOCTTY );
    if (fd <0) {perror(MODEMDEVICE); exit(-1); }
    tcgetattr(fd,&oldtio);
    bzero(&newtio, sizeof(newtio));
    newtio.c_cflag = BAUDRATE | CRTSCTS | CS8 | CLOCAL | CREAD;
    newtio.c_iflag = IGNPAR;
    newtio.c_oflag = 0;
    newtio.c_lflag = 0;

     newtio.c_cc[VTIME] = 0;   
    newtio.c_cc[VMIN] = 5;  

    tcflush(fd, TCIFLUSH);
    tcsetattr(fd,TCSANOW,&newtio);

    //pthread_setcancelstate(PTHREAD_CANCEL_ENABLE, NULL);
    //pthread_setcanceltype(PTHREAD_CANCEL_ASYCHRONOUS, NULL);

    while (STOP==FALSE)
    {   
        pthread_testcancel();
        res = read(fd,buf,255);
        pthread_testcancel();
        buf[res]=0;
        printf(":%s:%d\n", buf, res);
        if (buf[0]=='z') STOP=TRUE;
    }
     tcsetattr(fd,TCSANOW,&oldtio);
}

int main()
{
    int ret;
    pthread_t tid;
    ret = pthread_create(&tid, NULL, (void*)myThread, NULL);
    if (ret)
    {
        printf("pthread error!\n");
        return 1;
    }
    sleep(10);
}

如果你对这篇内容有疑问,欢迎到本站社区发帖提问 参与讨论,获取更多帮助,或者扫码二维码加入 Web 技术交流群。

扫码二维码加入Web技术交流群

发布评论

需要 登录 才能够评论, 你可以免费 注册 一个本站的账号。

评论(1

流绪微梦 2022-10-22 05:41:56

pthread_join

~没有更多了~
我们使用 Cookies 和其他技术来定制您的体验包括您的登录状态等。通过阅读我们的 隐私政策 了解更多相关信息。 单击 接受 或继续使用网站,即表示您同意使用 Cookies 和您的相关数据。
原文