问题
在更新到Xcode 12之后,使用模拟器编译时我得到了下面这条报错信息:
Could not find module ‘XXX’ for target ‘arm64-apple–ios–simulator’; found: x86_64-apple–ios–simulator, x86_6
这条报错只有在使用模拟器时会出现,使用真机是可以正常编译运行的。
分析
根据报错信息可以看出,这是个关于模拟器编译支持架构的问题。这个字段的意思就是需要编译哪些架构,报错的意思是说某个库试图针对arm64架构编译,而我们的模拟器或者说我们的开发机是x86_64架构,因此编译失败。
我猜测原因是Xcode 12的更新适配了基于arm的Mac。首先明确一点,iOS模拟器的架构就是开发机的架构,而不是对应真机的架构。虽然iPhone是arm架构,但原来的Mac电脑还是都是x86架构的,所以Xcode的iOS模拟器也是x86_64架构(太老的32位的i386不说了)。但在苹果推出自研的Apple Silicon之后,开发机就有可能是arm架构了,在开发机上的模拟器自然也变成arm架构了。在某些设置下,Xcode 12很有可能为所有的有效架构进行编译,而arm64在Xcode 12之后也被视作有效架构,如果在原本的intel x86架构的Mac上编译,就会导致错误。
但是这并不是绝对的,对于Xcode Build的各种设置甚至是第三方库的引入都可能改变最终编译的架构,涉及的Build Settings就包括了VALID_ARCHS, Excluded Architectures, Build Active Architecture Only等。解决办法也多种多样,每个人可能都不一样,下面我提出一些可能的解决办法,可以都尝试一下看哪个能够解决。