当前位置: 首页 > article >正文

告别.so库:用Android.mk直接编译C/C++可执行文件,在Android设备上运行命令行工具

告别.so库用Android.mk直接编译C/C可执行文件在Android设备上运行命令行工具当大多数Android开发者还在JNI和共享库的世界里打转时一群极客已经发现了更原生的玩法——把Android设备当作完整的Linux环境来使用。想象一下你可以在Pixel手机上运行自己编译的ffmpeg命令行工具或者在电视盒子上部署定制版的busybox这种自由度正是通过BUILD_EXECUTABLE实现的魔法。1. 为什么需要Android原生可执行文件在嵌入式开发领域我们早已习惯直接与硬件对话。但当场景切换到Android设备时很多人却自动戴上了JNI的枷锁。实际上Android内核仍然是Linux这意味着它天然具备运行原生二进制文件的能力。以下是三种典型场景系统工具移植将Linux经典工具如sed、awk移植到Android环境算法快速验证绕过JNI开销直接运行C/C算法模块设备管理自动化通过adb shell执行定制化运维脚本与传统的.so共享库相比可执行文件具有明显的优势特性可执行文件共享库运行方式直接执行需Java层通过JNI调用启动速度毫秒级存在JNI调用开销调试复杂度GDB直接附加需要联合调试Java环境部署灵活性adb push即可需要打包进APK提示从Android 5.0开始PIE位置无关可执行文件成为强制要求这是直接编译可执行文件时最容易踩的坑。2. Android.mk的核心配置差异2.1 从共享库到可执行文件将BUILD_SHARED_LIBRARY替换为BUILD_EXECUTABLE只是开始完整的配置转型包含以下关键点LOCAL_PATH : $(call my-dir) include $(CLEAR_VARS) # 源文件配置支持多文件编译 LOCAL_SRC_FILES : \ main.c \ utils.c \ parser.c # 模块命名最终生成的可执行文件名 LOCAL_MODULE : my_tool # PIE安全要求Android 4.1必需 LOCAL_CFLAGS -pie -fPIE LOCAL_LDFLAGS -pie -fPIE # 静态库链接如有需要 LOCAL_STATIC_LIBRARIES : libzip # 关键差异点生成可执行文件 include $(BUILD_EXECUTABLE)2.2 多ABI支持策略针对不同的设备架构NDK提供了灵活的编译控制# 在Application.mk中定义推荐 APP_ABI : armeabi-v7a arm64-v8a x86 x86_64 # 或在命令行指定 ndk-build APP_ABIarm64-v8a架构选择需要考虑以下因素性能需求arm64-v8a支持更先进的指令集兼容范围armeabi-v7a覆盖90%以上的旧设备开发效率x86架构在模拟器上调试更快3. 实战编译BusyBox核心组件让我们以编译BusyBox的ls命令为例演示完整流程准备源码树mkdir -p jni/{busybox,prebuilt} cp -r busybox-1.36.0/* jni/busybox/精简配置# Android.mk LOCAL_SRC_FILES : busybox/coreutils/ls.c LOCAL_CFLAGS -DSTANDALONE交叉编译ndk-build NDK_PROJECT_PATH. APP_BUILD_SCRIPTAndroid.mk部署测试adb push libs/arm64-v8a/ls /data/local/tmp adb shell chmod x /data/local/tmp/ls adb shell /data/local/tmp/ls -l常见问题解决方案符号链接缺失使用-DSTANDALONE编译选项权限不足推送到/data/local/tmp目录GLIBC冲突静态链接必要的库4. 高级技巧与性能优化4.1 调试技巧使用NDK提供的gdbserver可以实现在设备上调试# 在设备端启动调试服务 adb shell gdbserver :5039 /data/local/tmp/my_tool # 在主机端连接 ndk-gdb --start4.2 性能调优通过编译选项提升执行效率LOCAL_CFLAGS \ -O3 \ -marcharmv8-a \ -mtunecortex-a75 \ -flto关键优化点LTO链接优化减少最终二进制体积NEON指令集启用SIMD并行计算内存对齐防止缓存行失效4.3 系统集成将工具集成到系统PATH中# 需要root权限 adb push my_tool /system/xbin adb shell chmod 755 /system/xbin/my_tool adb shell chcon u:object_r:system_file:s0 /system/xbin/my_tool注意修改/system分区需要解锁bootloader部分厂商设备可能限制写入。5. 现代替代方案CMake与可执行文件虽然Android.mk仍然有效但Google推荐使用CMake进行原生开发。以下是等效的CMake配置cmake_minimum_required(VERSION 3.4.1) add_executable(my_tool src/main.c src/utils.c) target_compile_options(my_tool PRIVATE -pie -fPIE) target_link_options(my_tool PRIVATE -pie -fPIE)迁移建议新项目直接采用CMake旧项目通过ndk-build保持兼容混合构建在CMake中调用Android.mk模块在Pixel 6 Pro上实测相同算法在可执行文件中的运行速度比通过JNI调用快15-20%这主要得益于消除了JNI转换开销。对于需要频繁调用的工具类操作直接使用原生可执行文件无疑是更高效的选择。

相关文章:

告别.so库:用Android.mk直接编译C/C++可执行文件,在Android设备上运行命令行工具

告别.so库:用Android.mk直接编译C/C可执行文件,在Android设备上运行命令行工具 当大多数Android开发者还在JNI和共享库的世界里打转时,一群极客已经发现了更原生的玩法——把Android设备当作完整的Linux环境来使用。想象一下,你可…...

LLM学术反驳技术:DRPG框架解析与应用实践

1. LLM在学术反驳场景中的技术实现路径大型语言模型在学术论文反驳场景的应用,本质上是一个多阶段的认知任务分解过程。DRPG(Decompose-Retrieve-Plan-Generate)框架的创新性在于将复杂的反驳撰写任务拆解为可管理的子任务链。这种设计源于对…...

告别蝴蝶纹:SNAP中Sentinel-1 DInSAR处理的核心步骤拆解与原理浅析

告别蝴蝶纹:SNAP中Sentinel-1 DInSAR处理的核心步骤拆解与原理浅析 雷达干涉测量(DInSAR)技术通过分析合成孔径雷达(SAR)影像间的相位差异,能够精确捕捉地表毫米级形变。对于Sentinel-1这类TOPS模式数据&am…...

Outfit字体:9种字重的开源几何无衬线字体完全指南

Outfit字体:9种字重的开源几何无衬线字体完全指南 【免费下载链接】Outfit-Fonts The most on-brand typeface 项目地址: https://gitcode.com/gh_mirrors/ou/Outfit-Fonts 在数字化设计时代,字体不仅是文字的载体,更是品牌形象的核心…...

Py-Scrcpy-Client Cython编译错误解决方案:企业级Android投屏技术选型与实施指南

Py-Scrcpy-Client Cython编译错误解决方案:企业级Android投屏技术选型与实施指南 【免费下载链接】py-scrcpy-client 项目地址: https://gitcode.com/gh_mirrors/py/py-scrcpy-client 在构建高性能Android设备投屏解决方案时,Py-Scrcpy-Client作…...

等保 2.0 干货合集,网工升职加薪必备常识

等保 2.0 干货合集,网工升职加薪必备常识 想象一下,你负责维护的网络突然遭遇攻击,数据泄露、业务瘫痪,损失惨重,而这一切仅仅因为安全措施没到位。作为网络的“设计师”和“守护者”,网工的职责早已不限于…...

JavaSE-12-Java多线程零基础入门核心概念精讲

目录 一、进程与线程:结合SpringBoot实战场景彻底搞懂 1.1 新手必答三大疑问(结合开发日常) 1.2 进程核心概念通俗理解 1.3 线程核心概念通俗理解 1.4 进程与线程核心区别 1.5 Java线程底层运行机制实操演示代码 实操代码:查…...

Akagi智能麻将助手完全教程:AI实时分析提升雀魂水平

Akagi智能麻将助手完全教程:AI实时分析提升雀魂水平 【免费下载链接】Akagi 支持雀魂、天鳳、麻雀一番街、天月麻將,能夠使用自定義的AI模型實時分析對局並給出建議,內建Mortal AI作為示例。 Supports Majsoul, Tenhou, Riichi City, Amatsuk…...

GHelper:告别臃肿控制中心,华硕笔记本性能优化终极指南

GHelper:告别臃肿控制中心,华硕笔记本性能优化终极指南 【免费下载链接】g-helper Lightweight, open-source control tool for ASUS laptops and ROG Ally. Manage performance modes, fans, GPU, battery, and RGB lighting across Zephyrus, Flow, TU…...

Dubbo相关面试题

一、Dubbo服务注册和发现的流程?1、容器启动; 2、服务提供者连接注册中心,将接口信息保存到注册中心中; 3、服务消费者从注册中心订阅所需要的服务并缓存本地, 4、服务提供方有变更时,注册中心将提供一份新…...

明日方舟游戏素材资源库:你的创意宝库终极指南

明日方舟游戏素材资源库:你的创意宝库终极指南 【免费下载链接】ArknightsGameResource 明日方舟客户端素材 项目地址: https://gitcode.com/gh_mirrors/ar/ArknightsGameResource 还在为找不到高质量的明日方舟素材而烦恼吗?ArknightsGameResour…...

【困难】0左边必有1的二进制字符串数量-Java:解法二

分享一个大牛的人工智能教程。零基础!通俗易懂!风趣幽默!希望你也加入到人工智能的队伍中来!请轻击人工智能教程大家好!欢迎来到我的网站! 人工智能被认为是一种拯救世界、终结世界的技术。毋庸置疑&#x…...

微信聊天记录永久保存指南:WeChatExporter开源工具完整教程

微信聊天记录永久保存指南:WeChatExporter开源工具完整教程 【免费下载链接】WeChatExporter 一个可以快速导出、查看你的微信聊天记录的工具 项目地址: https://gitcode.com/gh_mirrors/wec/WeChatExporter 你是否曾担心珍贵的微信聊天记录会因手机损坏或更…...

Depth-Anything-V2深度解析:单目深度估计基础模型的架构设计与实战应用

Depth-Anything-V2深度解析:单目深度估计基础模型的架构设计与实战应用 【免费下载链接】Depth-Anything-V2 [NeurIPS 2024] Depth Anything V2. A More Capable Foundation Model for Monocular Depth Estimation 项目地址: https://gitcode.com/gh_mirrors/de/D…...

2025届学术党必备的五大AI科研工具解析与推荐

Ai论文网站排名(开题报告、文献综述、降aigc率、降重综合对比) TOP1. 千笔AI TOP2. aipasspaper TOP3. 清北论文 TOP4. 豆包 TOP5. kimi TOP6. deepseek 已然广泛应用于学术写作范畴的人工智能技术,给毕业论文的撰写供给了高效的辅助工…...

无似然温度采样算法解析与应用实践

1. 无似然温度采样算法解析温度采样是控制生成模型输出的核心技术,传统方法通过调整softmax前的logits实现概率分布重缩放。但在无似然框架(如CALM)中,由于只能访问采样器而无法获取显式概率分布,这一方法面临根本性挑…...

用TensorFlow 2.x和DenseNet121,手把手教你搭建一个数学图形分类器(附完整代码)

基于TensorFlow 2.x与DenseNet121的数学图形分类实战指南 在计算机视觉领域,数学图形分类是一个极具教育意义的入门项目。不同于常见的猫狗分类或人脸识别,几何图形识别任务具有明确的特征边界和规则性结构,非常适合初学者理解卷积神经网络的…...

告别臃肿!用Hono在Cloudflare Workers上5分钟搭建一个超轻量API(附完整代码)

边缘计算新选择:用Hono在5分钟内构建高性能API服务 当我们需要快速构建一个轻量级API服务时,传统框架往往显得过于臃肿。Cloudflare Workers作为边缘计算平台,配合Hono这样的微型框架,能实现惊人的部署速度和运行效率。本文将带你…...

AB 触摸屏常用操作步骤及常见问题解决方案

AB 触摸屏常用操作步骤及常见问题解决方案 1:顾客备份的后缀.mer如何打开? 如图导入,即可自动.med文件,在文件处打开即可。2:后缀.mer 如何导入触摸屏? 一:U盘导入 二:ME传输3&#…...

高效PR沟通:提升代码协作效率的关键技巧

1. 为什么PR沟通如此重要?在代码协作开发中,Pull Request(PR)是开发者之间最重要的沟通载体之一。一个典型的PR生命周期中,沟通环节往往占据70%以上的时间成本。根据GitHub官方统计,处理良好的PR沟通能使代…...

C. Partitioning the Array

原题:Problem - C - Codeforces 官方题解:Editorial for Codeforces Round #919 (Div. 2) - Codeforces 收获及反思: 同余推理,如: 判断x,y两数是否可能同余,并找出模数m. 设相同的余数为k, xa*mk, yb*m…...

Ryujinx Switch模拟器:5个简单步骤让您在PC上畅玩任天堂游戏

Ryujinx Switch模拟器:5个简单步骤让您在PC上畅玩任天堂游戏 【免费下载链接】Ryujinx 用 C# 编写的实验性 Nintendo Switch 模拟器 项目地址: https://gitcode.com/GitHub_Trending/ry/Ryujinx 想要在电脑上体验《塞尔达传说:王国之泪》《集合啦…...

RT-Thread下MPU6050的I2C驱动避坑指南:从硬件连接到DMP解算全流程

RT-Thread下MPU6050的I2C驱动避坑指南:从硬件连接到DMP解算全流程 在嵌入式开发领域,姿态传感器已成为无人机、平衡车、VR设备等智能硬件的核心组件。MPU6050作为一款集成6轴运动跟踪的经典传感器,凭借其高性价比和丰富功能,在RT-…...

数据安全治理是什么?数据安全治理有哪些步骤?

近几年,企业因数据安全问题遭受损失的情况越来越频繁。监管罚单、勒索病毒、内部泄露,随便哪一样都能让企业脱层皮。很多公司以为买几个防火墙、装个杀毒软件就万事大吉,结果真出事时才发现根本防不住。因为数据安全并不是简单的技术问题&…...

Python高频交易引擎性能压测全记录:从50μs到8μs的7大关键优化步骤

更多请点击: https://intelliparadigm.com 第一章:Python高频交易引擎性能压测全记录:从50μs到8μs的7大关键优化步骤 在实盘环境模拟中,我们基于 ccxt asyncio 构建的订单路由引擎初始平均延迟为 50.3μs(P99&…...

Python 3.15 WASM编译器首次开源:仅需2条命令生成可嵌入HTML的.pywasm文件,附GitHub Star破万的starter模板

更多请点击: https://intelliparadigm.com 第一章:Python 3.15 WASM 轻量化部署 Python 3.15 正式引入实验性 WASM(WebAssembly)后端支持,允许将纯 Python 模块编译为 .wasm 二进制文件,在浏览器或 WASI 运…...

Docker AI Toolkit 2026兼容性矩阵全曝光(覆盖CUDA 12.4–12.8 / ROCm 6.2 / Apple M4 Ultra),你的硬件在支持列表第几位?

更多请点击: https://intelliparadigm.com 第一章:Docker AI Toolkit 2026 兼容性矩阵全景解析 Docker AI Toolkit 2026 是面向生成式AI工作流深度优化的容器化工具集,其兼容性设计覆盖从边缘设备到超算集群的全栈基础设施。与传统AI镜像不…...

kew快速入门指南:10个命令让你立即开始播放音乐

kew快速入门指南:10个命令让你立即开始播放音乐 【免费下载链接】kew Music for the Shell. 项目地址: https://gitcode.com/gh_mirrors/ke/kew kew是一款专为命令行用户设计的音乐播放器,让你无需离开终端即可享受高品质音乐体验。本文将通过10个…...

如何快速掌握ASP.NET Core MVC:面向开发者的完整实战指南

如何快速掌握ASP.NET Core MVC:面向开发者的完整实战指南 【免费下载链接】Mvc [Archived] ASP.NET Core MVC is a model view controller framework for building dynamic web sites with clean separation of concerns, including the merged MVC, Web API, and W…...

MCP插件生态搭建全链路拆解,覆盖协议注册、能力协商、上下文同步与热重载调试

更多请点击: https://intelliparadigm.com 第一章:MCP插件生态搭建全景概览 MCP(Model Control Protocol)作为新一代模型交互协议,其插件生态是实现大模型能力可扩展、可编排与可治理的核心基础设施。插件并非孤立模块…...