如何为 macOS 创建 Rust 通用二进制文件 (x86_64 & aarch64)

如何为 macOS 创建 Rust 通用二进制文件 (x86_64 & aarch64)

本文档将指导您如何将一个 Rust 项目编译并打包成一个 macOS 通用二进制文件,使其能够同时在搭载 Intel (x86_64) 和 Apple Silicon (aarch64) 芯片的 Mac 电脑上原生运行。

什么是通用二进制文件?

通用二进制文件(Universal Binary)是苹果公司的一种文件格式,它可以在一个可执行文件中包含多个架构的代码。这意味着同一个应用程序可以在不同类型的 Mac 电脑上以最佳性能运行,而无需用户下载不同版本的软件。

先决条件

在开始之前,请确保您的系统已安装以下工具:

  • Rust 工具链 : 包括 rustccargo。您可以通过 rustup 来管理它们。

操作步骤

以下是将 Rust 项目打包成通用二进制文件的详细步骤。

步骤 1: 安装目标平台

为了能够交叉编译到不同的架构,您需要使用 rustup 安装相应的目标平台工具链。

打开终端并运行以下命令来安装 Intel (x86_64) 和 Apple Silicon (aarch64) 的目标平台:

bash 复制代码
rustup target add x86_64-apple-darwin
rustup target add aarch64-apple-darwin

步骤 2: 为每个架构编译项目

接下来,您需要分别为两个目标平台编译您的 Rust 项目。请确保在发布模式 (--release) 下进行编译,以获得最佳性能。

为 Intel (x86_64) 平台编译:

bash 复制代码
cargo build --release --target x86_64-apple-darwin

为 Apple Silicon (aarch64) 平台编译:

bash 复制代码
cargo build --release --target aarch64-apple-darwin

编译完成后,您将在 target/x86_64-apple-darwin/release/target/aarch64-apple-darwin/release/ 目录下找到对应平台的可执行文件。

步骤 3: 使用 lipo 合并二进制文件

lipo 是一个 macOS 命令行工具,用于创建和操作通用文件。我们将使用它来将两个平台的可执行文件合并成一个单一的通用二进制文件。

首先,创建一个用于存放通用二进制文件的目录:

bash 复制代码
mkdir -p target/universal

然后,使用 lipo 命令进行合并。假设您的项目名称为 your_project_name

bash 复制代码
lipo -create -output target/universal/your_project_name-universal \
     target/x86_64-apple-darwin/release/your_project_name \
     target/aarch64-apple-darwin/release/your_project_name

注意 : 请将 your_project_name 替换为您项目的实际名称。在我们的示例中,项目名称是 test-,可执行文件是 test-,最终的通用二进制文件是 test-universal

步骤 4: 验证通用二进制文件

为了确保合并成功,您可以使用 file 命令来检查生成的可执行文件所包含的架构。

bash 复制代码
file target/universal/your_project_name-universal

如果命令成功执行,您应该会看到类似以下的输出,表明该文件同时包含了 x86_64arm64 两种架构:

ini 复制代码
target/universal/your_project_name-universal: Mach-O universal binary with 2 architectures: [x86_64:Mach-O 64-bit executable x86_64] [arm64]

步骤 5: 运行可执行文件

现在,您可以直接运行这个通用二进制文件。系统会自动选择与当前 Mac 架构匹配的代码来执行。

bash 复制代码
./target/universal/your_project_name-universal

总结

通过以上步骤,您已经成功地将一个 Rust 项目打包成了一个适用于两种主流 Mac 芯片架构的通用二进制文件。这简化了软件的分发过程,并为所有用户提供了最佳的本地性能体验。

相关推荐
Momentary_SixthSense4 小时前
serde
开发语言·rust·json
百锦再4 小时前
金仓数据库提出“三低一平”的迁移理念
开发语言·数据库·后端·python·rust·eclipse·pygame
星释6 小时前
Rust 练习册 4:Deref trait 与智能指针
开发语言·后端·rust
林太白7 小时前
rust12-路由接口
后端·rust
fruge12 小时前
Vue项目中的Electron桌面应用开发实践指南
前端·vue.js·electron
Source.Liu19 小时前
【ISO8601】ISO8601 Rust 库完整学习指南
rust·time
像风一样自由202019 小时前
Rust与Python完全指南:从零开始理解两门语言的区别与关系
开发语言·python·rust
2301_7965125221 小时前
Rust编程学习 - 如何学习有关函数和闭包的高级特性,这包括函数指针以及返回闭包
服务器·学习·rust
小灰灰搞电子1 天前
Rust Slint实现控件尺寸的扩展与收缩源码分享
开发语言·后端·rust