linux c fifo阻塞写和非阻塞写,linux—FIFO的使用与非阻塞标志(O_NONBLOCK)的影响

FIFO文

#include

#include

int mkfifo( const char*pathname, mode_t mode);

参数:

pathname:FIFO的路径名+文件名。

mode:mode_t类型的权限描述符,同open的参数。

返回值:

成功:返回0

失败:如果文件已经存在,则会出错且返回-1。

操作FIFO文件时的特点:

系统调用的I/O函数都可以作用于FIFO,如open、close、read、write等。

打开FIFO时,非阻塞标志(O_NONBLOCK)产生下列影响:

特点一:不指定O_NONBLOCK(即open没有位或O_NONBLOCK)

1、open以只读方式打开FIFO时,要阻塞到某个进程为写而打开此FIFO

2、open以只写方式打开FIFO时,要阻塞到某个进程为读而打开此FIFO。

3、open以只读、只写方式打开FIFO时会阻塞,调用read函数从FIFO里读数据时read也会阻塞。

4、调用write函数向FIFO里写数据,当缓冲区已满时write也会阻塞。

5、通信过程中若写进程先退出了,则调用read函数从FIFO里读数据时不阻塞;若写进程又重新运行,则调用read函数从FIFO里读数据时又恢复阻塞。

6、通信过程中,读进程退出后,写进程向命名管道内写数据时,写进程也会(收到SIGPIPE信号)退出。

特点二:指定O_NONBLOCK(即open位或O_NO

  • 1
    点赞
  • 4
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
以下是使用C语言实现SCHED_FIFO算法的代码示例: ```c #include <stdio.h> #include <stdlib.h> #include <unistd.h> #include <sched.h> #include <errno.h> #define STACK_SIZE 1024*1024 void* thread_function(void* arg); int main() { int thread_id; pthread_t thread; pthread_attr_t attr; struct sched_param param; int policy; void* stack; // 分配线程栈 stack = malloc(STACK_SIZE); if (stack == NULL) { perror("malloc"); exit(EXIT_FAILURE); } // 初始化线程属性 if (pthread_attr_init(&attr) != 0) { perror("pthread_attr_init"); exit(EXIT_FAILURE); } // 设置线程栈 if (pthread_attr_setstack(&attr, stack, STACK_SIZE) != 0) { perror("pthread_attr_setstack"); exit(EXIT_FAILURE); } // 设置调度策略为SCHED_FIFO policy = SCHED_FIFO; if (pthread_attr_setschedpolicy(&attr, policy) != 0) { perror("pthread_attr_setschedpolicy"); exit(EXIT_FAILURE); } // 设置线程优先级 param.sched_priority = 50; if (pthread_attr_setschedparam(&attr, &param) != 0) { perror("pthread_attr_setschedparam"); exit(EXIT_FAILURE); } // 创建线程 if (pthread_create(&thread, &attr, &thread_function, NULL) != 0) { perror("pthread_create"); exit(EXIT_FAILURE); } // 等待线程结束 if (pthread_join(thread, NULL) != 0) { perror("pthread_join"); exit(EXIT_FAILURE); } // 销毁线程属性 if (pthread_attr_destroy(&attr) != 0) { perror("pthread_attr_destroy"); exit(EXIT_FAILURE); } free(stack); exit(EXIT_SUCCESS); } void* thread_function(void* arg) { // 打印线程信息 printf("Thread running.\n"); printf("Thread priority: %d\n", sched_get_priority_min(SCHED_FIFO)); printf("Thread policy: %d\n", sched_getscheduler(0)); // 让线程休眠5秒钟 sleep(5); printf("Thread finished.\n"); return NULL; } ``` 在以上示例中,我们使用了pthread库来创建线程,设置线程属性和等待线程结束。在主函数中,我们首先分配线程栈,然后初始化线程属性。接着,我们设置线程栈和调度策略为SCHED_FIFO,并设置线程优先级为50。然后,我们创建线程,等待线程结束,销毁线程属性,释放线程栈,并退出程序。 在线程函数中,我们打印线程信息,让线程休眠5秒钟,然后打印线程结束信息并返回NULL。

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值