修改FFMpeg的日志函数av_log,使其在记录日志时能显示调用该函数的位置(文件名和行号)

需要注释掉原有的 av_log 声明和实现,然后将新代码添加到 log.h 中。以下是完整、优化的实现方案:

在log.h中添加一下代码,已定义新的av_log函数。

c 复制代码
// log.h

#include <stdio.h>

// 修改函数签名,增加 file 和 line 参数
static void av_log_impl(void* avcl, int level, const char *file, int line, const char *fmt, ...) {
    va_list vl;
    va_start(vl, fmt);

    // 动态拼接调用位置信息(避免缓冲区溢出)
    char new_fmt[1024];
    snprintf(new_fmt, sizeof(new_fmt), "[%s:%d] %s", file, line, fmt);

    av_vlog(avcl, level, new_fmt, vl); // 调用底层日志函数
    va_end(vl);
}

// 定义包装宏:在调用点展开 __FILE__ 和 __LINE__
#define av_log(avcl, level, fmt, ...) \
    av_log_impl(avcl, level, __FILE__, __LINE__, fmt, ##__VA_ARGS__)

需要同时进行的修改:

  1. 在实现文件中注释掉原有函数定义

    在你的实现文件(如 log.c)中找到原函数并注释掉:

    c 复制代码
    // void av_log(void* avcl, int level, const char *fmt, ...)
    // {
    //     ... 原有实现 ...
    // }
  2. 注释掉原来的av_log声明

    在 log.h 中,注释掉原来的av_log声明:

    c 复制代码
     // 注释掉原来的av_log声明
     // void av_log(void* avcl, int level, const char *fmt, ...);
  3. 确保 av_vlog 可用

    确保在 log.h 中声明了 av_vlog 函数:

    c 复制代码
    void av_vlog(void* avcl, int level, const char *fmt, va_list vl);

关键优化说明:

  1. 安全缓冲区

    • 使用固定大小缓冲区避免动态内存分配
    • 安全截断确保不会越界 (snprintf 的自动截断特性)
  2. 性能考虑

    • static 函数定义避免符号冲突
    • 内联调用位置信息仅在启用日志时才处理
  3. 编译器兼容性

    • ##__VA_ARGS__ 处理 GNU C/C++ 的空参数情况
    • 使用标准 C99 特性保证可移植性
  4. 日志格式灵活性

    如果想添加更多上下文(如函数名),可扩展为:

    c 复制代码
    #define av_log(avcl, level, fmt, ...) \
        av_log_impl(avcl, level, __FILE__, __LINE__, __func__, fmt, ##__VA_ARGS__)

    然后在函数中修改格式字符串为 "[%s:%d] %s: %s"

这样修改后,所有调用 av_log 的地方都会自动添加准确的位置信息,例如:

c 复制代码
av_log(NULL, 1, "Starting playback");
// 输出格式: [player.c:42] Starting playback
相关推荐
luoqice7 小时前
RTMP视频流的帧格式分析
网络·ffmpeg
老姚---老姚1 天前
编译支持HEVC/H.265 over RTMP / Enhanced RTMP 的 ffmpeg
ffmpeg·h.265·hevc·rtmp·enhanced
码流怪侠2 天前
FFmpeg 开发实战全解析:从入门到精通(附完整代码示例)
ffmpeg·音视频开发·视频编码
圆弧YH2 天前
FFmpeg
ffmpeg
luoqice2 天前
FLV文件格式详解
ffmpeg
happybasic3 天前
在CMD下使用FFmpeg将.wav文件转换成指定的格式~
ffmpeg
shao9185163 天前
第10章 Streaming(上):初级音频应用(1)——项目三:自建服务器的Mini-Omni实时语音聊天机器人
ffmpeg·whisper·asr·mini-omni·自建语音服务器
Leon_Chenl4 天前
【已开源】【嵌入式 Linux 音视频+ AI 实战项目】瑞芯微 Rockchip 系列 RK3588-基于深度学习的人脸门禁+ IPC 智能安防监控系统
深度学习·opencv·yolo·ffmpeg·音视频·边缘计算·人脸识别+检测
antzou4 天前
视频图片/文字水印
ffmpeg·视频水印·批量水印
AC赳赳老秦5 天前
DBA 专属方案:用 OpenClaw 实现 SQL 语句优化、慢查询分析、数据库备份巡检全自动化
服务器·前端·数据库·ffmpeg·自动化·deepseek·openclaw