首页
/ 【亲测免费】 使用指南: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
deepin linux kernel
C
27
11
docsdocs
OpenHarmony documentation | OpenHarmony开发者文档
Dockerfile
514
3.69 K
ops-mathops-math
本项目是CANN提供的数学类基础计算算子库,实现网络在NPU上加速计算。
C++
873
538
pytorchpytorch
Ascend Extension for PyTorch
Python
316
360
kernelkernel
openEuler内核是openEuler操作系统的核心,既是系统性能与稳定性的基石,也是连接处理器、设备与服务的桥梁。
C
333
152
RuoYi-Vue3RuoYi-Vue3
🎉 (RuoYi)官方仓库 基于SpringBoot,Spring Security,JWT,Vue3 & Vite、Element Plus 的前后端分离权限管理系统
Vue
1.31 K
732
flutter_flutterflutter_flutter
暂无简介
Dart
757
182
nop-entropynop-entropy
Nop Platform 2.0是基于可逆计算理论实现的采用面向语言编程范式的新一代低代码开发平台,包含基于全新原理从零开始研发的GraphQL引擎、ORM引擎、工作流引擎、报表引擎、规则引擎、批处理引引擎等完整设计。nop-entropy是它的后端部分,采用java语言实现,可选择集成Spring框架或者Quarkus框架。中小企业可以免费商用
Java
12
1
leetcodeleetcode
🔥LeetCode solutions in any programming language | 多种编程语言实现 LeetCode、《剑指 Offer(第 2 版)》、《程序员面试金典(第 6 版)》题解
Java
67
20
openHiTLSopenHiTLS
旨在打造算法先进、性能卓越、高效敏捷、安全可靠的密码套件,通过轻量级、可剪裁的软件技术架构满足各行业不同场景的多样化要求,让密码技术应用更简单,同时探索后量子等先进算法创新实践,构建密码前沿技术底座!
C
1.05 K
519