关于linux多线程同时对一个fd做select

多线程(多进程也是差不多的情况),select同一个fd,发现在某些情况下面,的确会有多个线程(进程)被唤醒,然后只有一个线程能够accept(stream类型的fd)或者recv(如果是diagram的fd),其它的则会在accept或recv处阻塞,当然如果把fd设成非阻塞的,则会返回一个失败。

所以多线程同时select一个fd时,还是把fd设成非阻塞的,省得麻烦。因为循环处理时,往往也顺便在没有事件发生时,顺带做一些定时器的工作,这时如果堵住了,就不是好事了,没法去处理定时器计费了。

 

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
嵌入式Linux多线程管道的使用步骤如下: 1. 创建管道:使用pipe()函数创建一个管道。该函数返回两个文件描述符,一个用于读取管道中的数据,一个用于写入管道中的数据。 2. 创建多个线程:使用pthread_create()函数创建多个线程。每个线程都可以使用管道的写入文件描述符向管道中写入数据。 3. 在主线程中读取管道中的数据:使用管道的读取文件描述符从管道中读取数据。可以使用select()或poll()函数来检查管道是否有数据可读,以避免阻塞主线程。 4. 在多个线程中向管道中写入数据:在每个线程中,使用管道的写入文件描述符向管道中写入数据。可以使用write()函数向管道中写入数据。 示例代码如下: ``` #include <stdio.h> #include <stdlib.h> #include <pthread.h> #include <unistd.h> #include <errno.h> #define PIPE_SIZE 4096 int pipe_fd[2]; void *thread_func(void *arg) { char buf[PIPE_SIZE]; int ret; sprintf(buf, "Data from thread %d", *(int *)arg); ret = write(pipe_fd[1], buf, PIPE_SIZE); if (ret == -1) { perror("write() failed"); exit(EXIT_FAILURE); } pthread_exit(NULL); } int main() { pthread_t tid[5]; int i, ret; char buf[PIPE_SIZE]; ret = pipe(pipe_fd); if (ret == -1) { perror("pipe() failed"); exit(EXIT_FAILURE); } for (i = 0; i < 5; i++) { ret = pthread_create(&tid[i], NULL, thread_func, &i); if (ret != 0) { perror("pthread_create() failed"); exit(EXIT_FAILURE); } } for (i = 0; i < 5; i++) { ret = read(pipe_fd[0], buf, PIPE_SIZE); if (ret == -1) { perror("read() failed"); exit(EXIT_FAILURE); } printf("%s\n", buf); } return 0; } ``` 该示例代码创建了一个管道,然后创建了5个线程,每个线程向管道中写入一条数据。最后,在主线程中从管道中读取5条数据并输出。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值