简介
avformat_open_input函数初始化AVFormatContext结构体。其中在初始化AVIOContext结构体参数中调用init_input函数,而它会默认调用av_probe_input_buffer2填充AVIOContext结构体参数。一般情况下,可以优先调用av_probe_input_buffer函数,填充AVIOContext结构体参数,然后赋值给AVFormatContext结构体中的AVIOContext字段
代码
AVIOContext pIOContext= avio_alloc_context
AVInputFormat pInputFormat = NULL
av_probe_input_buffer(pIOContext, &pInputFormat, "", NULL, 0, 0)
AVFormatContext* pFormatContext = avformat_alloc_context();
pFormatContext->pb = pIOContext;
if (avformat_open_input(&FormatContext, "", pInputFormat, NULL) <0)
根据av_probe_input_buffer会调用av_probe_input_buffer2&#xff0c;包裹了一层
简化代码如下
AVFormatContext* pFormatContext &#61; avformat_alloc_context();
if (avformat_open_input(&FormatContext, "", pInputFormat, NULL) <0)
根据实际的测试&#xff0c;关键的地方是AVIOContext的初始化&#xff0c;该结构体将会保存一个读取网络数据的函数入口&#xff0c;根据函数入口来分析数据流。avformat_open_input函数在目前的
测试结果是耗时1秒多&#xff0c;这个应该是一个优化的方向
av_probe_input_buffer2主要是针对输入输出结构体AVIOContext的初始化&#xff0c;如果知道avformat_open_input的赋值内容&#xff0c;对各种协议的读写格式的探测&#xff0c;就可以优化这一块代码。协议的探测分别有file协议&#xff0c;rtmp协议等等&#xff0c;目前在项目中只需要实现文件协议&#xff0c;而文件协议应该如何进行读写&#xff1f;
调用ffio_fdopen()函数创建AVIOContext()结构体并获取URLContext结构体引用的资源&#xff08;调用avio_alloc_context()实现&#xff09;