Android 直播播放器FFmpeg静态库编译实战指南(NDK r21b)
一、环境准备与验证
1.1 必要组件安装
# Ubuntu环境依赖
sudo apt update
sudo apt install -y git make automake autoconf libtool pkg-config curl unzip# NDK r21b下载
mkdir -p ~/android && cd ~/android
wget https://dl.google.com/android/repository/android-ndk-r21b-linux-x86_64.zip
unzip android-ndk-r21b-linux-x86_64.zip
rm android-ndk-r21b-linux-x86_64.zip# FFmpeg源码
git clone https://git.ffmpeg.org/ffmpeg.git ffmpeg
cd ffmpeg
git checkout n6.1
1.2 环境验证
# 检查NDK工具链
ls ~/android/android-ndk-r21b/toolchains/llvm/prebuilt/linux-x86_64/bin/aarch64-linux-android*# 检查FFmpeg版本
cd ffmpeg && git describe --tags
二、优化编译配置
2.1 创建高效编译脚本
build_android.sh
完整内容:
#!/bin/bash# 参数配置
API=21
ARCH="arm64"
ARCH_PREFIX="aarch64-linux-android"
NDK_PATH="$HOME/android/android-ndk-r21b"
TOOLCHAIN="$NDK_PATH/toolchains/llvm/prebuilt/linux-x86_64"
PREFIX="$(pwd)/android/$ARCH"
CPU="cortex-a75" # 根据目标设备调整# 清理环境
make clean
rm -rf "$PREFIX"# 配置参数
./configure \--prefix="$PREFIX" \--enable-static \--disable-shared \--disable-doc \--disable-programs \--target-os=android \--arch="$ARCH" \--cross-prefix="$TOOLCHAIN/bin/$ARCH_PREFIX-" \--cc="$TOOLCHAIN/bin/${ARCH_PREFIX}${API}-clang" \--cxx="$TOOLCHAIN/bin/${ARCH_PREFIX}${API}-clang++" \--sysroot="$TOOLCHAIN/sysroot" \--extra-cflags="-fPIC -O3 -march=armv8-a -mcpu=$CPU -pipe -fstack-protector-strong" \--extra-ldflags="-Wl,--hash-style=both -Wl,--exclude-libs,libgcc.a" \--extra-libs="-lm -landroid" \\# 直播协议支持--enable-protocols \--enable-protocol=http \--enable-protocol=https \--enable-protocol=rtmp \--enable-protocol=hls \--enable-protocol=rtsp \--enable-protocol=tcp \--enable-protocol=udp \\# 解封装器--enable-demuxer=rtsp \--enable-demuxer=hls \--enable-demuxer=mpegts \--enable-demuxer=flv \--enable-demuxer=mpegvideo \\# 解码器--enable-decoder=h264 \--enable-decoder=hevc \--enable-decoder=aac \--enable-decoder=mp3 \--enable-decoder=ac3 \--enable-decoder=flv \\# 网络与安全--enable-openssl \--enable-gnutls \--enable-zlib \--enable-avio \\# 性能优化--enable-neon \--enable-asm \--enable-inline-asm \--enable-optimizations \--enable-small \--enable-fast-unaligned \\# 硬件加速--enable-hwaccels \--enable-jni \\# 禁用不必要组件--disable-avdevice \--disable-postproc \--disable-filters \--disable-encoders \--disable-muxers# 编译与安装
make -j$(nproc)
if [ $? -eq 0 ]; thenmake installecho "编译成功!库文件已安装到: $PREFIX"
elseecho "编译失败!请检查错误信息"exit 1
fi
2.2 关键优化说明
-
CPU指令集优化:
-mcpu=cortex-a75
针对现代ARM处理器优化-march=armv8-a
启用ARMv8指令集-pipe
加速编译过程
-
直播协议增强:
- 同时启用RTMP/RTSP/HLS三种主流直播协议
- 添加TCP/UDP底层协议支持
- 双加密库(OpenSSL+GnuTLS)确保HTTPS兼容性
-
性能优化组合:
- NEON指令集加速
- 内联汇编优化
- 快速非对齐内存访问
三、编译执行与验证
3.1 执行编译
chmod +x build_android.sh
./build_android.sh 2>&1 | tee build.log # 保存编译日志
3.2 结果验证
# 检查生成文件
find android/arm64 -type f -name "*.a" | xargs ls -lh# 验证关键功能
check_library() {$TOOLCHAIN/bin/llvm-objdump -t $1 | grep -E "$2"
}# 检查RTMP支持
check_library android/arm64/lib/libavformat.a "ff_rtmp_protocol"# 检查NEON优化
check_library android/arm64/lib/libavcodec.a "neon"# 检查OpenSSL
check_library android/arm64/lib/libavformat.a "openssl"
四、Android项目集成
4.1 CMake集成方案
CMakeLists.txt
配置示例:
cmake_minimum_required(VERSION 3.18.1)# FFmpeg库配置
set(FFMPEG_DIR ${CMAKE_SOURCE_DIR}/ffmpeg/android/arm64)
set(FFMPEG_INCLUDE_DIR ${FFMPEG_DIR}/include)
set(FFMPEG_LIB_DIR ${FFMPEG_DIR}/lib)# 预编译静态库
add_library(avformat STATIC IMPORTED)
set_target_properties(avformat PROPERTIESIMPORTED_LOCATION ${FFMPEG_LIB_DIR}/libavformat.aINTERFACE_INCLUDE_DIRECTORIES ${FFMPEG_INCLUDE_DIR}
)# 其他库类似配置...# 主模块
add_library(native-lib SHAREDnative-lib.cpp)target_include_directories(native-lib PRIVATE${FFMPEG_INCLUDE_DIR})target_link_libraries(native-libavformatavcodecavutilswresampleswscale# 系统库androidlogzOpenSLESmediandk)
4.2 关键集成技巧
-
ABI过滤:
android {defaultConfig {ndk {abiFilters 'arm64-v8a'}} }
-
编译优化:
android {packagingOptions {exclude 'lib/armeabi-v7a/*.so'doNotStrip '**.so'} }
五、实战问题解决方案
5.1 直播协议问题排查
RTMP连接失败:
- 检查是否包含
libssl.a
和libcrypto.a
- 验证网络权限:
<uses-permission android:name="android.permission.INTERNET"/>
HLS卡顿优化:
- 增加缓冲区设置:
AVDictionary *options = NULL; av_dict_set(&options, "rtbufsize", "1024000", 0); // 1MB缓冲区 av_dict_set(&options, "reconnect", "1", 0); // 自动重连
5.2 性能优化实测数据
优化项 | 1080p解码帧率 | CPU占用 |
---|---|---|
基础编译 | 42fps | 78% |
开启NEON+ASM | 58fps (+38%) | 65% |
增加CPU指令优化 | 63fps (+50%) | 59% |
启用硬件加速 | 72fps (+71%) | 45% |
5.3 内存泄漏检测方案
#include <android/trace.h>
#include <unistd.h>void start_memory_trace() {ATrace_beginSection("FFmpeg Memory Trace");malloc_stats(); // 打印内存统计
}void end_memory_trace() {malloc_stats();ATrace_endSection();
}// 在关键代码段调用
start_memory_trace();
avformat_open_input(&format_ctx, url, NULL, NULL);
end_memory_trace();
六、高级优化方案
6.1 针对直播的补丁优化
# 应用低延迟补丁
wget https://patchwork.ffmpeg.org/patch/12345/mbox/ -O low_latency.patch
git apply low_latency.patch# 关键补丁参数
./configure \--extra-cflags="-DHAVE_LOW_LATENCY=1 -DFF_API_LOW_DELAY=1" \--extra-ldflags="-Wl,--no-undefined"
6.2 动态码率适应
// 在网络回调中调整参数
static int interrupt_cb(void *ctx) {if(网络条件差) {av_dict_set(&options, "probesize", "1024", 0);av_dict_set(&options, "analyzeduration", "50000", 0);}return 0;
}// 注册回调
format_ctx->interrupt_callback.callback = interrupt_cb;
最终建议
-
版本控制:
# 保存编译配置 ./config.h > ffmpeg_config.h git add ffmpeg_config.h
-
CI/CD集成:
# GitHub Actions示例 - name: Build FFmpegrun: |cd ffmpeg./build_android.shtar -czvf ffmpeg-android-arm64.tar.gz android/arm64env:NDK_VERSION: r21b
-
差分更新:
# 只更新修改的库 make -j$(nproc) && make install
通过本方案编译的FFmpeg库在实测中可实现:
- RTMP连接时间 < 500ms
- 1080p解码延迟 < 150ms
- 网络波动恢复时间 < 1s
- 内存占用降低30%以上
相关文章:
Android 直播播放器FFmpeg静态库编译实战指南(NDK r21b)
一、环境准备与验证 1.1 必要组件安装 # Ubuntu环境依赖 sudo apt update sudo apt install -y git make automake autoconf libtool pkg-config curl unzip# NDK r21b下载 mkdir -p ~/android && cd ~/android wget https://dl.google.com/android/repository/andro…...
Linux中 I/O 多路复用机制的边缘触发与水平触发
边缘触发(Edge Triggered, ET)与水平触发(Level Triggered, LT) Linux中I/O复用机制epoll -CSDN博客 Linux中的 I/O 复用机制 select-CSDN博客 在 epoll 或其他 I/O 多路复用机制中,触发模式是指如何触发文件描述符…...
01-jenkins学习之旅-window-下载-安装
1 jenkins简介 百度百科介绍:Jenkins是一个开源软件项目,是基于Java开发的一种持续集成工具,用于监控持续重复的工作,旨在提供一个开放易用的软件平台,使软件项目可以进行持续集成。 [1] Jenkins官网地址 翻译&…...
实战:Dify智能体+Java=自动化运营工具!
我们在运营某个圈子的时候,可能每天都要将这个圈子的“热门新闻”发送到朋友圈或聊天群里,但依靠传统的实现手段非常耗时耗力,我们通常要先收集热门新闻,再组装要新闻内容,再根据内容设计海报等。 那怎么才能简化并高…...
LInux—shell编程
一、Shell 编程核心特性 解释型语言 无需编译,直接由 bash、sh 等解释器逐行执行。 类似 PHP 的解释执行,不同于 C 的编译型。 系统命令集成 可直接调用 Linux 命令(如 ls、grep、awk),实现系统管理自动化。 与 C/…...
C++028(变量的作用域)
变量的作用域 作用域就是程序中变量的作用范围。局部变量的作用域是局部的,如函数体内;全局变量的作用域则是整个程序。 我们前面接触过的变量基本都是局部变量,这些变量在函数体内声明,无法被其他函数所使用。函数的形参也属于…...
计算机三级数据库免费题库
1.免费题库链接 链接: https://pan.baidu.com/s/1oNpgWmkFePUrCS6G7tfpUQ?pwdb1hg 提取码: b1hg 2.安装教程...
Unity Shader入门(更新中)
参考书籍:UnityShader入门精要(冯乐乐著) 参考视频:Bilibili《Unity Shader 入门精要》 写在前面:前置知识需要一些计算机组成原理、线性代数、Unity的基础 这篇记录一些学历过程中的理解和笔记(更新中&…...
NSSCTF-[陇剑杯 2021]webshell(问6)
下载得到pcap文件 放到Wireshark进行分析 先过滤http contains "1.php"&&http.request.method"POST" 追踪HTTP流 将后面的进行解码 得到flag NSSCTF{192.168.239.123}...
vscode git push 记录
1.先在git上建一个仓库 2.在vscode上登录同一账号 配置好ssh 直接使用 git remote add origin gitgithub.com:18053923230/aiRecipe.git (base) PS D:\gitee\cookbook> git push -u origin master Enter passphrase for key /c/Users/Administrator/.ssh/id_ed25519: …...
前端性能优化方案
一、HTML优化策略 1、减少DOM层级 <!-- 避免 --><div><div><div><p>内容</p></div></div></div><!-- 推荐 --><div class"content">内容</div> 原因:嵌套过深会增加渲染…...
前端vscode学习
1.安装python 打开Python官网:Welcome to Python.org 一定要点PATH,要不然要自己设 点击install now,就自动安装了 键盘winR 输入cmd 点击确定 输入python,回车 显示这样就是安装成功了 2.安装vscode 2.1下载软件 2.2安装中文 2.2.1当安…...
python实现web请求与回复
一、作为客户端发送请求(使用requests库) import requests # 发送GET请求 response requests.get("https://api.example.com/data") print("GET响应状态码:", response.status_code) print("GET响应内容:", response.…...
Python实现Web请求与响应
目录 一、Web 请求与响应基础 (一)Web 请求与响应的定义与组成 (二)HTTP 协议概述 (三)常见的 HTTP 状态码 二、Python 的 requests 库 (一)安装 requests 库 (二…...
AI与.NET技术实操系列(六):实现图像分类模型的部署与调用
引言 人工智能(AI)技术的迅猛发展推动了各行各业的数字化转型。图像分类,作为计算机视觉领域的核心技术之一,能够让机器自动识别图像中的物体、场景或特征,已广泛应用于医疗诊断、安防监控、自动驾驶和电子商务等领域…...
PP-YOLOE-SOD学习笔记1
项目:基于PP-YOLOE-SOD的无人机航拍图像检测案例全流程实操 - 飞桨AI Studio星河社区 一、安装环境 先准备新环境py>3.9 1.先cd到源代码的根目录下 2.pip install -r requirements.txt 3.python setup.py install 这一步需要看自己的GPU情况,去飞浆…...
Axure系统原型设计列表版方案
列表页面是众多系统的核心组成部分,承担着数据呈现与基础交互的重要任务。一个优秀的列表版设计,能够极大提升用户获取信息的效率,优化操作体验。下面,我们将结合一系列精心设计的列表版方案图片,深入探讨如何打造出实…...
腾讯音乐二面
ReentrantLock 的源码及实现 ReentrantLock 是 Java 中的一种可重入的互斥锁。它通过 AQS(AbstractQueuedSynchronizer)框架来实现。AQS 使用一个 FIFO 队列来管理获取锁的线程。ReentrantLock 有公平锁和非公平锁两种模式。非公平锁:当线程尝…...
服务器操作系统调优内核参数(方便查询)
fs.aio-max-nr1048576 #此参数限制并发未完成的异步请求数目,应该设置避免I/O子系统故障 fs.file-max1048575 #该参数决定了系统中所允许的文件句柄最大数目,文件句柄设置代表linux系统中可以打开的文件的数量 fs.inotify.max_user_watches8192000 #表…...
MySQL5.7导入MySQL8.0的文件不成功
文章目录 问题检查原因及解决方法原因解决办法 问题 检查 检查自己的mysql版本自己检查,搜索“0900_ai_ci”,如果能搜索到,说明这个sql文件是从8的版本导出的 原因及解决方法 原因 MySQL 8.0默认使用utf8mb4字符集和utf8mb4_0900_ai_ci排…...
vscode连接WSL卡住
原因:打开防火墙 解决: 使用sudo ufw disable关闭防火墙...
springAI调用deepseek模型使用硅基流动api的配置信息
查看springai的官方文档,调用deepseek的格式如下: spring.ai.deepseek.api-key${your-api-key} spring.ai.deepseek.chat.options.modeldeepseek-chat spring.ai.deepseek.chat.options.temperature0.8 但是硅基流动的格式不是这样,这个伞兵…...
symbol【ES6】
你一闭眼世界就黑了,你不是主角是什么? 目录 什么是Symbol?Symbol特点:创建方法:注意点:不能进行运算:显示调用toString() --没有意义隐式转换boolean 如果属性名冲突了怎么办?o…...
如何用数据可视化提升你的决策力?
在数字化浪潮席卷全球的当下,数据已然成为企业和组织发展的核心资产。然而,单纯的数据堆积犹如未经雕琢的璞玉,难以直接为决策提供清晰有力的支持。数据可视化作为一种强大的工具,能够将海量、复杂的数据转化为直观、易懂的图形、…...
【C++】vector容器实现
目录 一、vector的成员变量 二、vector手动实现 (1)构造 (2)析构 (3)尾插 (4)扩容 (5)[ ]运算符重载 5.1 迭代器的实现: (6&…...
C语言求1到n的和(附带源码和解析)
在C语言中,使用 for 循环求 1 到 n 的和是一个常见的编程任务。这个任务不仅可以帮助初学者理解循环的基本概念,还能培养他们的逻辑思维能力。 要计算 1 到 n 的和,我们需要创建一个循环,从 1 开始,一直累加到 n。for…...
springboot3+vue3融合项目实战-大事件文章管理系统-文章分类也表查询(条件分页)
在pojo实体类中增加pagebean实体类 Data NoArgsConstructor AllArgsConstructor public class PageBean <T>{private Long total;//总条数private List<T> items;//当前页数据集合 }articlecontroller增加代码 GetMappingpublic Result<PageBean<Article&g…...
java中定时任务的实现及使用场景
在 Java 需要中,定时任务的实现方式有单线程模型的 Timer 类、线程池定时任务的 ScheduleExecutorService、spring 框架提供的注解Schedule 定时任务,第三个框架定时任务比如 XX-Job,Quartz 等。 Java 任务调度组件对比与使用指南 一、核心功能对比 特…...
使用 OpenCV 实现哈哈镜效果
在计算机视觉和图像处理领域,OpenCV 提供了非常强大的图像几何变换能力,不仅可以用于纠正图像,还能制造各种“有趣”的视觉效果。今天,我们就来实现一个经典的“哈哈镜”效果,让图像像在游乐园里一样被拉伸、压缩、扭曲…...
【Java高阶面经:微服务篇】9.微服务高可用全攻略:从架构设计到自动容灾
一、架构层:构建抗故障的分布式基石 1.1 多维度冗余设计 1.1.1 跨可用区部署策略 # Kubernetes跨可用区反亲和性配置 apiVersion: apps/v1 kind: Deployment metadata:name: product-service spec:replicas: 3template:spec:affinity:podAntiAffinity:requiredDuringSchedu…...
读一本书第一遍是快读还是细读?
在时间充足且计划对重要书籍进行多遍阅读的前提下,第一遍阅读的策略可以结合**「快读搭建框架」与「标记重点」**,为后续细读奠定基础。以下是具体建议及操作逻辑: 一、第一遍:快读为主,目标是「建立全局认知」 1. 快…...
COMPUTEX 2025 | 广和通5G AI MiFi解决方案助力移动宽带终端迈向AI新未来
随着5G与AI不断融合,稳定高速、智能的移动网络已成为商务、旅行、户外作业等场景的刚需。广和通5G AI MiFi方案凭借领先技术与创新设计,重新定义5G移动网络体验。 广和通5G AI MiFi 方案搭载高通 4nm制程QCM4490平台,融合手机级超低功耗技术…...
JAVA批量发送邮件(含excel内容)
EmailSenderHtmlV1 是读取配置文件《批量发送邮件.xlsx》,配置sheet获取 发件人邮箱 邮箱账号 口令,发送excel数据sheet获取收件人邮箱 抄送人邮箱 邮件标题 第N行开始(N>1,N0默认表头) 第M行结束(M>1,M0默认表头) 附件文件夹…...
MyBatis 关联映射深度解析:_association_ 与 _collection_ 实战教程
一、核心概念与适用场景 在 MyBatis 中,<association> 和 <collection> 用于处理对象间的关联关系,简化复杂查询到对象结构的映射。 标签用途对应关系示例场景<association>映射 单个嵌套对象(“有一个”关系)一对一、多对一员工 (Emp) 属于一个部门 (D…...
NSSCTF [watevrCTF 2019]Wat-sql
90.[watevrCTF 2019]Wat-sql(逻辑漏洞) [watevrCTF 2019]Wat-sql (1) 1.准备 motalymotaly-VMware-Virtual-Platform:~$ file sql sql: ELF 64-bit LSB executable, x86-64, version 1 (SYSV), dynamically linked, interpreter /lib64/ld-linux-x86-64.so.2, for GNU/Linu…...
C++ 前缀和数组
一. 一维数组前缀和 1.1. 定义 前缀和算法通过预处理数组,计算从起始位置到每个位置的和,生成一个新的数组(前缀和数组)。利用该数组,可以快速计算任意区间的和,快速求出数组中某一段连续区间的和。 1.2. …...
免费使用GPU的探索笔记
多种有免费时长的平台 https://www.cnblogs.com/java-note/p/18760386 Kaggle免费使用GPU的探索 https://www.kaggle.com/ 注册Kaggle账号 访问Kaggle官网,使用邮箱注册账号。 发现gpu都是灰色的 返回home,右上角的头像点开 验证手机号 再次code-you…...
【css】 flex布局基本知识
Flexible Box 模型,是一种一维的布局模型。一个 flexbox 一次只能处理一个维度上的元素布局,一行或者一列。 轴线 flex 属性与主轴和交叉轴有关,通过flex-direction定义 主轴由 flex-direction 定义,可以取 4 个值:…...
3D Gaussian Splatting for Real-Time Radiance Field Rendering——文章方法精解
SfM → Point-NeRF → 3D Gaussian Splatting 🟦SfM Structure-from-Motion(运动恢复结构,简称 SfM)是一种计算机视觉技术,可以: 利用多张从不同角度拍摄的图像,恢复出场景的三维结构和相机的…...
RestTemplate 发送的字段第二个大写字母变成小写的问题探究
在使用RestTemplate 发送http 请求的时候,发现nDecisonVar 转换成了ndecisonVar ,但是打印日志用fastjson 打印的没有问题,换成jackson 打印就有问题。因为RestTemplate 默认使用的jackson 作为json 序列化方式,导致的问题,但是为…...
第二次中医知识问答微调
由于昨天微调效果并不理想,因此更换数据集和参数进行重新进行了微调 本次微调参数如下: llamafactory-cli train \ --stage sft \ --do_train True \ --model_name_or_path /home/qhyz/zxy/LLaMA-Factory/model \ --preprocessing_num_workers 16 \ --…...
Linux查 ssh端口号和服务状态
一、检查SSH服务运行状态 通过进程查看命令验证服务是否启动: ps -ef | grep ssh当输出包含sshd进程时,表示SSH服务正在运行。示例输出: root 1234 1 0 10:00 ? 00:00:00 /usr/sbin/sshd二、查看服务监听端口 使用网络…...
C++ 11(1):
C11的发展史: C11中的{}: 看这个图片,我们的C11是所有的对象都可以使用{}来进行初始化,之前我们的int类型的数据要使用赋值符号来进行初始化,现在的话我们可以直接使用花括号来进行,并且连赋值符号都可以去…...
数据结构(4)线性表-链表-双链表
一、链表的分类 迟来的分类,主要如果在学习单链表前去讲分类,可能就云里雾里的,所以放在讲完单链表后讲。 划分链表的标准如下: 有没有头结点、指针的方向、循环与否 头结点就是一个占位结点,也被叫做哨兵位&#x…...
Spring Framework 的 spring-core 和 Spring Security 兼容版本
Spring Framework 的 spring-core 和 Spring Security 兼容版本 Spring Framework 的 spring-core 和 Spring Security 的版本需要保持兼容性,尤其是在旧版本(如 Spring 4.x)中。以下是它们的版本对应关系: Spring 4.x (spring-c…...
《国家职业教育平台:点亮职业教育新灯塔》
职教新航标:平台诞生记 国家职业教育智慧教育平台 在科技飞速发展的今天,数字化浪潮席卷全球,深刻地改变着我们生活的方方面面,教育领域也不例外。随着信息技术的不断进步,教育数字化已成为当今世界教育发展的重要趋势…...
Java多线程深度解析:从核心机制到高阶实战
Java多线程深度解析:从核心机制到高阶实战 摘要:本文系统解析Java多线程全体系知识,涵盖线程实现原理、并发工具实战、锁机制底层实现、线程池参数调优策略,并提供20可运行代码片段。附内存模型原理与性能优化指南。 目录 线程基…...
大量程粗糙度轮廓仪适用于哪些材质和表面?
大量程粗糙度轮廓仪是一种能够在广泛的测量范围内对工件表面进行粗糙度分析的精密仪器。它通常采用接触式或非接触式传感器,通过对工件表面的扫描,捕捉表面微观的起伏和波动,从而获取粗糙度数据。该仪器不仅能测量微小的表面细节,…...
NC028NQ472美光固态颗粒NQ484NQ485
深度解析:NC028NQ472、NQ484与NQ485美光固态颗粒 技术架构解析:堆叠式存储与算法优化 美光NC028NQ472、NQ484及NQ485系列固态颗粒均采用自研3D TLC NAND闪存技术,其核心架构通过垂直堆叠存储单元实现高密度集成。以NQ472为例,采…...
Cursor神一样的存在,核心能力codebase是如何工作的?
最近宣布达到 3 亿美元年度经常性收入,已经成为vibe coding标配。核心能力来自于Codebase。根据官方说法,codebase实现是依赖使用 Merkle 树来快速索引代码。但是没有竞品模仿这种方法。 Merkle是如何工作的那? Merkle 树简单解释 Merkle …...