我正在尝试在Xcode 12(beta 5)中构建一个大型(正在开发Xcode 11!)项目,为iOS 14做准备。代码库以前是Objective-C中的,但现在它同时包含Objective-C和Swift,并使用Objective-C或Swift的pod。

我已经推出了支持Xcode 12的CocoaPods新测试版(目前为1.10.0.beta 2)。

Pod安装成功。当我进行构建时,在pod框架上出现以下错误:

为iOS模拟器构建,但链接到为iOS构建的对象文件中,用于体系结构arm64

以及可能的错误:

无法加载目标“arm64-apple-ios11.0”的标准库

当我在框架上运行lipo-info时,它有:armv7s armv7 i386 x86_64 arm64。

此前,该项目的有效架构设置为:armv7、armv7s和arm64。

在Xcode 12中,根据苹果的文档,该设置将消失。架构设置为$(ARCH_STANDARD)。我在排除的架构中没有任何设置。

这里可能发生了什么?我还没能用一个更简单的项目重现这一点。


当前回答

我也遇到了通过迦太基安装的特定库的相同问题。对于那些正在使用迦太基的人来说,由于迦太基并没有现成的Xcode 12,本文档将指导您找到一种适用于大多数情况的解决方法。很快,Carthage构建了胖框架,这意味着该框架包含所有受支持架构的二进制文件。在引入Apple Silicon之前,它都工作得很好,但现在出现了冲突,因为存在重复的架构(arm64用于设备,arm64用于模拟器)。这意味着迦太基无法将特定于架构的框架链接到单个胖框架。

你可以按照这里的说明操作。迦太基XCODE 12

然后配置迦太基。在构建设置中将arm64置于“排除的体系结构”中。

尝试使用模拟器运行项目。模拟器应运行无任何错误。

其他回答

我相信我找到了答案。根据Xcode 12 beta 6发行说明:

“生成设置”编辑器不再包含有效体系结构生成设置(Valid_ARCHS),因此不鼓励使用它。取而代之的是新的“排除体系结构”生成设置(Excluded_ARCHS)。如果项目包含Valid_AARCHS,则该设置将显示在生成设置编辑器的“用户定义”部分中。(15145028)

我能够通过手动编辑项目文件(我无法确定如何使用Xcode从项目文件中删除该项)并删除所有引用VALID_ARCHS的行来解决此问题。之后,我可以很好地为模拟器进行构建。

截至2022年9月19日,所有现有答案都不适用于我。大多数答案建议将arm64从构建设置中排除,完成后,会出现致命错误:找不到模块映射文件

对我有用的是使用Rosseta打开Xcode,

右键单击应用程序文件夹中的Xcode显示简介使用Rosetta检查打开打开Xcode打开的项目清理生成文件夹运行项目

通过使用Rosseta打开Xcode,不需要其他构建设置或配置。

参考文献:

https://medium.com/timeless/starting-react-native-project-in-apple-mac-m1-chip-system-28da0c1f2132https://developer.apple.com/forums/thread/670006

请参阅此技术说明:https://developer.apple.com/documentation/technotes/tn3117-resolving-build-errors-for-apple-silicon排除模拟器的臂64应该是一个临时解决方案。

我在模拟器/SwiftUI预览中遇到了同样的问题,并出现以下警告:

ld:警告:忽略文件Pods//X.xcframework/ios-arm64_armv7/X.xcframework/X,文件中缺少所需的体系结构x86_64忽略文件Pods//X.xcframework/ios-arm64_armv7/X.xcframework/X(2个切片)

我在项目设置的框架搜索路径中有递归路径$(SRCROOT)。删除它后,项目将在没有错误的情况下生成。

升级到Xcode 12后,我仍然能够为真正的设备构建,但不能为模拟器构建。Podfile构建仅适用于真实设备。

我在Build Settings(构建设置)>User Defined(用户定义)下删除了VALID_ARCHS,它成功了!在发现这个之前,我先捶了一下脑袋。