fifo_read0fzc.c

#include <sys/types.h>
#include <sys/stat.h>
#include <errno.h>
#include <fcntl.h>
#include <stdio.h>
#include <stdlib.h>
#include <string.h>
#define FIFO "/tmp/myfifo"
main(int argc,char** argv)
{
    char buf_r[100];
    int  fd;
    int  nread;
   
    /* 创建管道 */
    if((mkfifo(FIFO,O_CREAT|O_EXCL)<0)&&(errno!=EEXIST))
        printf("cannot create fifoserver\n");
   
    printf("Preparing for reading bytes...\n");
    memset(buf_r,0,sizeof(buf_r));
   
    /* 打开管道 */
    fd=open(FIFO,O_RDONLY|O_NONBLOCK,0);
    if(fd==-1)
    {
        perror("open");
        exit(1);   
    }
    while(1)
    {
        memset(buf_r,0,sizeof(buf_r));
        if((nread=read(fd,buf_r,100))==-1)
        {
            if(errno==EAGAIN)
                printf("no data yet\n");
        }
        printf("read %s from FIFO\n",buf_r);
        sleep(1);
    }
    pause(); /*暂停,等待信号*/
    unlink(FIFO); //删除文件
}
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
非常抱歉给您带来困惑,实际上AVFifoBuffer并没有提供对互斥锁的原生支持,因此av_fifo_mutex_lock和av_fifo_mutex_unlock函数在ffmpeg的代码库中是不存在的。 如果需要在多线程环境中使用AVFifoBuffer,您可以使用线程库提供的互斥锁来保护FIFO缓冲区的访问。例如,可以使用pthread库提供的pthread_mutex_lock和pthread_mutex_unlock函数来实现互斥锁的加锁和解锁,示例代码如下: ```c #include <pthread.h> AVFifoBuffer *fifo; pthread_mutex_t mutex; void* write_thread(void* arg) { uint8_t* data = NULL; int data_size = 0; // 写入数据 while (1) { // 加锁 pthread_mutex_lock(&mutex); // 写入数据 if (av_fifo_space(fifo) >= data_size) { av_fifo_generic_write(fifo, data, data_size, NULL); } // 解锁 pthread_mutex_unlock(&mutex); } return NULL; } void* read_thread(void* arg) { uint8_t* data = NULL; int data_size = 0; // 读取数据 while (1) { // 加锁 pthread_mutex_lock(&mutex); // 读取数据 if (av_fifo_size(fifo) >= data_size) { av_fifo_generic_read(fifo, data, data_size, NULL); } // 解锁 pthread_mutex_unlock(&mutex); } return NULL; } int main() { // 初始化互斥锁 pthread_mutex_init(&mutex, NULL); // 创建FIFO缓冲区 fifo = av_fifo_alloc(1024); // 启动读写线程 pthread_t write_tid, read_tid; pthread_create(&write_tid, NULL, write_thread, NULL); pthread_create(&read_tid, NULL, read_thread, NULL); // 等待线程结束 pthread_join(write_tid, NULL); pthread_join(read_tid, NULL); // 释放资源 av_fifo_free(fifo); pthread_mutex_destroy(&mutex); return 0; } ``` 在上述示例中,我们使用了pthread库提供的pthread_mutex_lock和pthread_mutex_unlock函数来加锁和解锁互斥锁。需要注意的是,加锁和解锁的顺序必须保持一致,否则可能会导致死锁的问题。另外,如果需要在多个线程中使用FIFO缓冲区,需要对整个读取和写入过程加锁,以保证数据的安全。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值