iOS 报错 Undefined symbols for architecture x86_64:解决方法

     联系人:石虎 QQ:1224614774  昵称: 嗡嘛呢叭咪哄

                             QQ群:807236138  群称: iOS 技术交流学习群

                            QQ群:713799633   群称:iOS技术交流学习群-2

一、报错详情

 

Undefined symbols for architecture x86_64:

"_OBJC_CLASS_$_Person", referenced from:

_OBJC_CLASS_$_Dog in Dog.o

objc-class-ref in ViewController.o

"_OBJC_METACLASS_$_Person", referenced from:

_OBJC_METACLASS_$_Dog in Dog.o

ld: symbol(s) not found for architecture x86_64

clang: error: linker command failed with exit code 1 (use -v to see invocation)

 

 

 

二、解决方法

1:

2:在 build Phases 下操作如下

3:添加类文件

 

4:编译成功

 

 

 

三、造成 bug 原因,以及如何避免

 

1.造成 bug 原因是其它类没有参加编译造成的,这种原因又分成二种

 

2.如何避免

第一种:此框一定要勾选

 

第二种:此框一定要勾选

 

注意:如果忘记勾选,就在项目中的 Build Phases 中的 Compile Sources 中添加(详细前看图4)

 

谢谢!!!

本账号主要分享我成长过程中的各种心得感悟,包括技术总结, iOS、Swift 和 Mac 相关技术文章、工具资源、参与技术讨论,整理开发技巧、让学习成为一种享受!

Undefined symbol: _APMAnalyticsConfiguration Undefined symbol: _APMAppMeasurementOriginFirebase Undefined symbol: _APMConsentSettings3P Undefined symbol: _APMFormattedEventName Undefined symbol: _APMFormattedUserPropertyName Undefined symbol: _APMIsAnalyticsCollectionDeactivated Undefined symbol: _APMIsAnalyticsCollectionEnabled Undefined symbol: _APMIsValidTransactionDeviceVerification Undefined symbol: _APMMonitorLogTagOptionKey Undefined symbol: _APMUserDataFieldEmailAddress Undefined symbol: _APMUserDataFieldHashedEmailAddress Undefined symbol: _APMUserDataFieldHashedPhoneNumber Undefined symbol: _APMUserDataFieldPhoneNumber Undefined symbol: _OBJC_CLASS_$_APMAdExposureReporter Undefined symbol: _OBJC_CLASS_$_APMAnalytics Undefined symbol: _OBJC_CLASS_$_APMConditionalUserProperty Undefined symbol: _OBJC_CLASS_$_APMConditionalUserPropertyController Undefined symbol: _OBJC_CLASS_$_APMEvent Undefined symbol: _OBJC_CLASS_$_APMIdentifiers Undefined symbol: _OBJC_CLASS_$_APMIdentity Undefined symbol: _OBJC_CLASS_$_APMMeasurement Undefined symbol: _OBJC_CLASS_$_APMScreenViewReporter Undefined symbol: _OBJC_CLASS_$_APMUserAttribute Undefined symbol: _OBJC_CLASS_$_APMValue Undefined symbol: _OBJC_CLASS_$_MTGAdChoicesView Undefined symbol: _OBJC_CLASS_$_MTGBannerAdView Undefined symbol: _OBJC_CLASS_$_MTGBidNativeAdManager Undefined symbol: _OBJC_CLASS_$_MTGBidRewardAdManager Undefined symbol: _OBJC_CLASS_$_MTGBiddingSDK Undefined symbol: _OBJC_CLASS_$_MTGMediaView Undefined symbol: _OBJC_CLASS_$_MTGNewInterstitialAdManager Undefined symbol: _OBJC_CLASS_$_MTGNewInterstitialBidAdManager Undefined symbol: _OBJC_CLASS_$_MTGRewardAdManager Undefined symbol: _OBJC_CLASS_$_MTGSDK Undefined symbol: _OBJC_CLASS_$_MTGSplashAD Undefined symbol: _OBJC_METACLASS_$_APMAdExposureReporter Undefined symbol: _OBJC_METACLASS_$_APMConditionalUserProperty Undefined symbol: _OBJC_METACLASS_$_APMConditionalUserPropertyController Undefined symbol: _OBJC_METACLASS_$_APMEvent Undefined symbol: _OBJC_METACLASS_$_APMIdentifiers Undefined symbol: _OBJC_METACLASS_$_APMMeasurement Undefined symbol: _OBJC_METACLASS_$_APMScreenViewReporter Undefined symbol: _OBJC_METACLASS_$_APMUserAttribute Undefined symbol: _OBJC_METACLASS_$_APMValue XCODE 打包报错
最新发布
07-27
在Xcode打包过程中,出现`Undefined symbols for architecture`错误通常意味着链接器无法找到某些符号(如类、函数、变量等)的定义。如果这些符号与APM(应用性能管理)相关,则问题可能与第三方APM库的集成、配置或构建设置有关。 ### 常见原因与解决方案 #### 1. 缺少APM库的链接 如果项目中使用了APM SDK,但在构建时未正确链接其二进制文件(如`.a`、`.framework`、`.xcframework`),则会导致符号未定义错误。检查是否在`Build Phases > Link Binary With Libraries`中添加了所有必要的APM依赖库。 确保以下内容: - 所需的APM框架已正确添加。 - 使用CocoaPods时,确认`Podfile`中包含正确的APM依赖项,并执行了`pod install`[^1]。 #### 2. 构建配置问题 在某些情况下,APM库可能仅在特定构建配置(如Debug)中启用,而在Release或Archive构建中被排除。这可能导致打包时出现未定义符号。 解决方法- 检查`Build Settings > Other Linker Flags`,确保APM相关标志(如`-ObjC`、`-framework "APMSDK"`)适用于所有构建配置。 - 确保在Archive构建时未禁用APM模块或条件编译宏(如`#ifdef APM_ENABLED`)未生效[^1]。 #### 3. Bitcode设置不一致 如果APM库不支持Bitcode,但项目构建设置中启用了Bitcode,则可能导致链接失败。 解决方法- 进入`Build Settings > Enable Bitcode`,将其设置为`NO`,特别是对于Release和Archive配置[^1]。 #### 4. 使用CocoaPods时的依赖未正确构建 如果APM SDK通过CocoaPods集成,但Pod未正确构建或未与主项目同步,也可能导致符号缺失。 解决方法- 删除`Pods/`目录、`Podfile.lock`和`build/`缓存。 - 执行`pod deintegrate`后再次运行`pod install --repo-update`。 - 确保Xcode项目中Pods子项目的构建架构与主项目一致[^1]。 #### 5. 架构限制(Architectures)设置不当 如果APM库不支持某些CPU架构(如`arm64`、`x86_64`等),而项目构建时强制包含这些架构,可能导致链接失败。 解决方法- 检查`Build Settings > Architectures`,确保主项目与Pod项目的架构设置一致。 - 如果APM不支持模拟器架构(如x86_64),在Archive构建时应排除该架构[^1]。 #### 6. Swift与Objective-C混编问题 如果APM库是Objective-C编写,并在Swift项目中使用,但未正确桥接或导入,也可能导致符号找不到。 解决方法- 确保桥接头文件(Bridging Header)中正确导入APM头文件。 - 检查是否启用了`Defines Module`和`Product Module Name`设置,以便Swift能正确识别Objective-C模块[^1]。 #### 7. 使用静态库时未正确处理依赖传递 如果APM SDK本身依赖其他静态库或系统框架(如`CoreTelephony`、`SystemConfiguration`),而这些依赖未被显式链接,则可能导致链接失败。 解决方法- 在`Build Phases > Link Binary With Libraries`中添加APM依赖的系统框架。 - 确认静态库是否支持当前的iOS部署目标和架构[^1]。 --- ### 示例:检查Other Linker Flags设置 ```bash OTHER_LDFLAGS = ( "-framework \"APMSdk\"", "-ObjC", "-framework \"Pods-YourApp\"", ); ``` --- ### 示例:排除模拟器架构以避免冲突 在`Build Settings > Excluded Architectures`中添加: ``` x86_64 ``` 适用于Release和Archive配置。 ---
评论
成就一亿技术人!
拼手气红包6.0元
还能输入1000个字符
 
红包 添加红包
表情包 插入表情
 条评论被折叠 查看
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值