如何为 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 芯片架构的通用二进制文件。这简化了软件的分发过程,并为所有用户提供了最佳的本地性能体验。

相关推荐
浩星2 小时前
electron系列3:进程模型深度解析:主进程、渲染进程、预加载脚本
前端·electron·前端框架
迷藏4942 小时前
**发散创新:基于 Rust的模型保护机制设计与实践**在人工智能快速发
java·人工智能·python·rust·neo4j
love530love2 小时前
从零搭建本地版 Claurst:基于 Rust 重构的 Claude Code 终端编码助手 + LM Studio 模型接入测试
开发语言·人工智能·windows·重构·rust·lm studio·claude code
恋喵大鲤鱼2 小时前
如何理解 Rust 没有运行时(No Runtime)
rust
Tomhex1 天前
Rust数组与Vec的核心差异解析
rust
洒满阳光的庄园1 天前
Electron 桌面端打包流程说明
前端·javascript·electron
卸任1 天前
Electron霸屏功能总结
前端·react.js·electron
橘子编程1 天前
编程语言全指南:从C到Rust
java·c语言·开发语言·c++·python·rust·c#
是大强1 天前
electron调用dll 方案
前端·javascript·electron
亿牛云爬虫专家1 天前
学术文献爬虫 OOM 崩溃与 403 风暴
爬虫·rust·爬虫代理·403·oom killer·学术文献·403 forbidden