ffmpeg的AVBufferRef的用法

基于ffmpeg的4.2.2学习c实现的智能指针的用法:

1、用ref结构,类似于侵入式智能指针的思路,即把“数据”和“引用计数”绑到一个数据结构里,以防内存泄漏,机制简单。

2、用atomic的机制,保证引用计数ref的线程安全。

3、由于c实现的,没有重载“=”赋值符号,所以使用时注意别用错了。

示例如下:

extern "C" {
#include "libavutil/buffer.h"
}
#include 
using namespace std;

void av_buffer_default_free_2(void *opaque, uint8_t *data)
{
	free(data);
}

int main()
{
	const int size = 100;
	//需要被保护的数据data
	uint8_t *data = (uint8_t *)malloc(size);
	//用ref给保护起来
	AVBufferRef * buf = av_buffer_create(data, size + 64,
		av_buffer_default_free_2, NULL, 0);

	//////////////
	//加一次引用
	AVBufferRef* br = av_buffer_ref(buf);
	printf("ref count %d,%d\n", av_buffer_get_ref_count(br), av_buffer_get_ref_count(buf));

	//又加一次引用
	AVBufferRef* br2 = av_buffer_ref(br);
	printf("ref count %d,%d\n", av_buffer_get_ref_count(br), av_buffer_get_ref_count(buf));

	//开始解引用
	av_buffer_unref(&br);
	printf("ref count %d\n",  av_buffer_get_ref_count(buf));
	av_buffer_unref(&br2);
	printf("ref count %d\n", av_buffer_get_ref_count(buf));
	av_buffer_unref(&buf);
	if (NULL == buf)
	{
		printf("buf is released\n");
	}
	return 1;
}

其中av_buffer_default_free_2,是我自己实现的析构回调函数。由于这个版本默认av_buffer_default_free的默认回调函数不生效,所以我自己实现了一个。

你可能感兴趣的:(ffmpeg)