播放器缓存队列bug解决方案

背景

我在开发一个播放器的缓存队列时,遇到一个bug,导致包和帧无法被下一个模块读取

找了半天,原来是队列中的包和帧数据要进行内容的刷新暂存

包数据和帧数据不能直接放入队列

cpp 复制代码
//入队,包进队列
int AVPacketQueue::Push(AVPacket *val,int timeout)
{
    //加作用域互斥锁:资源同一时间只能有一个线程访问,作用域结束自动释放锁
    //std::lock_guard<std::mutex> lock(mutex_);

    std::unique_lock<std::mutex> lock(mutex_);//这里必须要加手动作用域互斥锁,因为wait_for需要作用域


    //因为是包队列-双链表
    //如果队满了,等待timeout时间
    if(duration_cur>=duration_MAX) {
        // 等待pop或者超时唤醒
        cond_.wait_for(lock, std::chrono::milliseconds(timeout), [this] {
            return duration_cur<duration_MAX;
        });
    }

    //如果依然队满,就直接返回-1
    if(duration_cur>=duration_MAX){
        return -1;
    }

    //入队:出现问题的代码,这里是直接把包指针存放到队列中了,但是在ffmpeg中不能直接存放,必须要先搞一个新包,然后刷新暂存数据
    queue_.push(val);

    //增加队列缓存时间,强转成ms
    long ms = static_cast<long>(av_rescale(val->duration, 1000, AV_TIME_BASE));

    this->duration_cur+=ms;

    cond_.notify_one();//条件变量:通知其他线程可以继续执行
    return 0;
}

解决方案

cpp 复制代码
//入队,包进队列
int AVPacketQueue::Push(AVPacket *val,int timeout)
{
    //加作用域互斥锁:资源同一时间只能有一个线程访问,作用域结束自动释放锁
    //std::lock_guard<std::mutex> lock(mutex_);

    std::unique_lock<std::mutex> lock(mutex_);//这里必须要加手动作用域互斥锁,因为wait_for需要作用域


    //因为是包队列-双链表
    //如果队满了,等待timeout时间
    if(duration_cur>=duration_MAX) {
        // 等待pop或者超时唤醒
        cond_.wait_for(lock, std::chrono::milliseconds(timeout), [this] {
            return duration_cur<duration_MAX;
        });
    }

    //如果依然队满,就直接返回-1
    if(duration_cur>=duration_MAX){
        return -1;
    }

    //入队:一定注意,必须要重新申请空间,不然会指向同一段地址,而且后面要释放对应的数据包av_packet_free
    AVPacket *tmp_packet = av_packet_alloc();
    av_packet_move_ref(tmp_packet, val);
    queue_.push(tmp_packet);

    //增加队列缓存时间,强转成ms
    long ms = static_cast<long>(av_rescale(val->duration, 1000, AV_TIME_BASE));

    this->duration_cur+=ms;

    cond_.notify_one();//条件变量:通知其他线程可以继续执行
    return 0;
}
相关推荐
知识即是力量ol4 小时前
基于 Redis 实现白名单,黑名单机制详解及应用场景
数据库·redis·缓存
fengxin_rou6 小时前
Redis 从零到精通:第一篇 初识redis
数据库·redis·缓存
陌上丨9 小时前
Redis内存使用率在95%以上,请问是什么原因?如何解决?
数据库·redis·缓存
dawdo22211 小时前
自己动手从头开始编写LLM推理引擎(9)-KV缓存实现和优化
缓存·llm·transformer·qwen·kv cache
小北方城市网12 小时前
RabbitMQ 生产级实战:可靠性投递、高并发优化与问题排查
开发语言·分布式·python·缓存·性能优化·rabbitmq·ruby
陌上丨12 小时前
什么是Redis的大Key和热Key?项目中一般是怎么解决的?
数据库·redis·缓存
小园子的小菜12 小时前
深入剖析HBase HFile原理:文件结构、Block协作与缓存机制
数据库·缓存·hbase
廋到被风吹走12 小时前
【缓存优化】缓存穿透:布隆过滤器(Guava/RedisBloom)
缓存·guava
Moshow郑锴13 小时前
Spring Boot Data API 与 Redis 集成:KPI/图表/表格查询的缓存优化方案
spring boot·redis·缓存
小马爱打代码13 小时前
MyBatis:缓存体系设计与避坑大全
java·缓存·mybatis