首页
/ 【亲测免费】 使用指南:cargo-ndk —— 面向Android的Rust编译工具

【亲测免费】 使用指南: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代码。

登录后查看全文
热门项目推荐
相关项目推荐

项目优选

收起
kernelkernel
openEuler内核是openEuler操作系统的核心,既是系统性能与稳定性的基石,也是连接处理器、设备与服务的桥梁。
C
471
465
kernelkernel
deepin linux kernel
C
32
16
atomcodeatomcode
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
ops-nnops-nn
本项目是CANN提供的神经网络类计算算子库,实现网络在NPU上加速计算。
C++
700
1.4 K
docsdocs
暂无描述
Dockerfile
780
5.08 K
pytorchpytorch
Ascend Extension for PyTorch
Python
758
968
flutter_flutterflutter_flutter
本仓库是 Flutter SDK 与 Flutter Engine 的 OpenHarmony 适配版本,由 CPF-Flutter 团队维护。开发者可使用熟悉的 Flutter 技术栈开发 OpenHarmony 应用,3.35.7 及以后的适配版本可基于本仓库源码构建支持 OpenHarmony 的 Flutter Engine。
Dart
1.04 K
271
ops-transformerops-transformer
本项目是CANN提供的transformer类大模型算子库,实现网络在NPU上加速计算。
C++
880
2.03 K
mindquantummindquantum
MindQuantum is a general software library supporting the development of applications for quantum computation.
Python
183
111
openHiTLSopenHiTLS
旨在打造算法先进、性能卓越、高效敏捷、安全可靠的密码套件,通过轻量级、可剪裁的软件技术架构满足各行业不同场景的多样化要求,让密码技术应用更简单,同时探索后量子等先进算法创新实践,构建密码前沿技术底座!
C
1.11 K
682