【亲测免费】 使用指南:cargo-ndk —— 面向Android的Rust编译工具
2026-01-25 06:31:37作者:谭伦延
cargo-ndk 是一个专为在Android平台上构建Rust代码而设计的Cargo扩展,它简化了环境配置,确保能够顺利生成适用于Android的库文件,并支持正确的jniLibs目录结构布局。
安装指南
要开始使用cargo-ndk,首先通过Cargo安装该扩展:
cargo install cargo-ndk
紧接着,确保安装所需的Android目标平台工具链:
rustup target add aarch64-linux-android armv7-linux-androideabi x86_64-linux-android i686-linux-android
上述命令将添加对不同架构的支持。
项目使用说明
cargo-ndk自动检测由Android Studio安装的NDK的默认位置并使用最新版本。如需指定特定NDK路径,则设置ANDROID_NDK_HOME环境变量。
构建示例
若需为32位和64位ARM系统构建库,执行以下命令:
cargo ndk -t armeabi-v7a -t arm64-v8a -o ./jniLibs build --release
这指定了构建的目标、输出目录以及传递给Cargo的常规标志。
链接与复制libc++_shared.so
在项目中创建build.rs文件,并加入以下代码来自动处理共享库的链接与复制:
use std::{env, path::PathBuf};
fn main() {
if env::var("CARGO_CFG_TARGET_OS").unwrap() == "android" {
android();
}
}
fn android() {
println!("cargo:rustc-link-lib=c++_shared");
if let Ok(output_path) = env::var("CARGO_NDK_OUTPUT_PATH") {
let sysroot_libs_path = PathBuf::from(env::var_os("CARGO_NDK_SYSROOT_LIBS_PATH").unwrap());
let lib_path = sysroot_libs_path.join("libc++_shared.so");
std::fs::copy(
lib_path,
Path::new(&output_path)
.join(&env::var("CARGO_NDK_ANDROID_TARGET").unwrap())
.join("libc++_shared.so"),
).expect("Copying shared library failed.");
}
}
控制日志级别
在Cargo命令后加上-v或-vv以调整详细程度。
API使用文档
cargo-ndk不直接提供API接口供应用程序调用,但通过一系列环境变量影响构建过程和脚本行为。重要环境变量有:
CARGO_NDK_ANDROID_PLATFORM:Android平台API编号。CARGO_NDK_ANDROID_TARGET:当前构建目标(例如armeabi-v7a)。CARGO_NDK_OUTPUT_PATH:指定的输出目录。- 其他环境变量允许你在构建脚本和其他场景下利用这些信息进行更精细的控制。
支持的主机系统
- Linux
- macOS (
x86_64,arm64) - Windows
对于本地开发,直接从源码安装即可:
git clone [仓库URL]
cd [克隆的仓库]
cargo install --path .
cargo-ndk为开发者提供了便捷途径来整合Rust与Android生态,通过以上步骤,您现在应该具备了所有必要的知识来有效地在Android项目中使用Rust代码。
登录后查看全文
热门项目推荐
相关项目推荐
atomcodeClaude Code 的开源替代方案。连接任意大模型,编辑代码,运行命令,自动验证 — 全自动执行。用 Rust 构建,极致性能。 | An open-source alternative to Claude Code. Connect any LLM, edit code, run commands, and verify changes — autonomously. Built in Rust for speed. Get StartedRust0218
cann-learning-hubCANN 学习中心仓,支持在线互动运行、边学边练,提供教程、示例与优化方案,一站式助力昇腾开发者快速上手。Jupyter Notebook0139
uni-appA cross-platform framework using Vue.jsJavaScript09
GLM-5.2智谱开源 GLM-5.2,这是针对长文本任务的最新旗舰模型。相较于前代产品 GLM-5.1,它在长文本任务处理能力上实现了显著飞跃,并且首次在稳定的 100 万 token 上下文中提供这一能力。Jinja00
SwanLab⚡️SwanLab - an open-source, modern-design AI training tracking and visualization tool. Supports Cloud / Self-hosted use. Integrated with PyTorch / Transformers / LLaMA Factory / veRL/ Swift / Ultralytics / MMEngine / Keras etc.Python00
tiny-universe《大模型白盒子构建指南》:一个全手搓的Tiny-UniverseJupyter Notebook03
项目优选
收起
openEuler内核是openEuler操作系统的核心,既是系统性能与稳定性的基石,也是连接处理器、设备与服务的桥梁。
C
471
465
deepin linux kernel
C
32
16
Claude Code 的开源替代方案。连接任意大模型,编辑代码,运行命令,自动验证 — 全自动执行。用 Rust 构建,极致性能。 | An open-source alternative to Claude Code. Connect any LLM, edit code, run commands, and verify changes — autonomously. Built in Rust for speed.
Get Started
Rust
2.09 K
218
本项目是CANN提供的神经网络类计算算子库,实现网络在NPU上加速计算。
C++
700
1.4 K
暂无描述
Dockerfile
780
5.08 K
Ascend Extension for PyTorch
Python
758
968
本仓库是 Flutter SDK 与 Flutter Engine 的 OpenHarmony 适配版本,由 CPF-Flutter 团队维护。开发者可使用熟悉的 Flutter 技术栈开发 OpenHarmony 应用,3.35.7 及以后的适配版本可基于本仓库源码构建支持 OpenHarmony 的 Flutter Engine。
Dart
1.04 K
271
本项目是CANN提供的transformer类大模型算子库,实现网络在NPU上加速计算。
C++
880
2.03 K
MindQuantum is a general software library supporting the development of applications for quantum computation.
Python
183
111
旨在打造算法先进、性能卓越、高效敏捷、安全可靠的密码套件,通过轻量级、可剪裁的软件技术架构满足各行业不同场景的多样化要求,让密码技术应用更简单,同时探索后量子等先进算法创新实践,构建密码前沿技术底座!
C
1.11 K
682