【iOS】SwiftUI導(dǎo)致iOS12及以下系統(tǒng)閃退問(wèn)題

背景

接入了新版的FirebaseSDK之后,測(cè)試發(fā)現(xiàn)iOS12系統(tǒng)閃退了,而iOS13及以上版本沒(méi)問(wèn)題。
通過(guò)下載iOS12模擬器進(jìn)行測(cè)試,發(fā)現(xiàn)iOS12模擬器啟動(dòng)崩潰了,里面的提示信息為

dyld: Library not loaded: /System/Library/Frameworks/SwiftUI.framework/SwiftUI
  Referenced from: /Users/handsome/Library/Developer/CoreSimulator/Devices/B7DD7057-0DC7-47B0-B783-D2BA487CE81B/data/Containers/Bundle/Application/3C31E11E-3716-4176-9C0F-6B3521637D07/SDKDemo.app/SDKDemo
  Reason: image not found
dyld: launch, loading dependent libraries
DYLD_FRAMEWORK_PATH=/Users/handsome/Library/Developer/Xcode/DerivedData/SDKDemo-cmgpdjdqjjgyinchqiukyuxwzynx/Build/Products/Debug-iphonesimulator
DYLD_FALLBACK_LIBRARY_PATH=/Library/Developer/CoreSimulator/Profiles/Runtimes/iOS 12.4.simruntime/Contents/Resources/RuntimeRoot/usr/lib
DYLD_ROOT_PATH=/Library/Developer/CoreSimulator/Profiles/Runtimes/iOS 12.4.simruntime/Contents/Resources/RuntimeRoot
DYLD_FALLBACK_FRAMEWORK_PATH=/Library/Developer/CoreSimulator/Profiles/Runtimes/iOS 12.4.simruntime/Contents/Resources/RuntimeRoot/System/Library/Frameworks
DYLD_INSERT_LIBRARIES=/Library/Developer/CoreSimulator/Profiles/Runtimes/iOS 12.4.simruntime/Contents/Resources/RuntimeRoot/usr/lib/libBacktraceRecording.dylib:/Library/Developer/CoreSimulator/Profiles/Runtimes/iOS 12.4.simruntime/Contents/Resources/RuntimeRoot/usr/lib/libMainThreadChecker.dylib:/Library/Developer/CoreSimulator/Profiles/Runtimes/iOS 12.4.simruntime/Contents/Resources/RuntimeRoot/Developer/Library/PrivateFrame

關(guān)鍵信息為 第一行
dyld: Library not loaded: /System/Library/Frameworks/SwiftUI.framework/SwiftUI
看樣子是SwiftUI的問(wèn)題,Google一波之后,確認(rèn)SwiftUI是iOS13開(kāi)始使用,iOS13以下是沒(méi)有的。
如果使用了SwiftUI,那么不進(jìn)行特別處理的話,在iOS12上會(huì)崩潰,哪怕你使用了#available進(jìn)行處理。
因?yàn)?strong>使用了SwiftUI之后Xcode會(huì)默認(rèn)導(dǎo)入SwiftUI.framework庫(kù)。而且默認(rèn)導(dǎo)入的framework都是Required類型。

解決方案

知道了原因之后,解決方案也就出來(lái)了,就是將SwiftUI.framework系統(tǒng)庫(kù)改為可選。目前有兩個(gè)解決方案:
方案一:
Build Phases選項(xiàng)卡中的 Link Binary With Libraries 里面添加 SwiftUI.framework,然后將Status改為Optional。

image.png

方案二:
Build Settings 選項(xiàng)卡中的 Other Linker Flags 設(shè)置里面添加 -weak_framework SwiftUI
image.png

檢查配置

目前確認(rèn)是跟SwiftUI.framework相關(guān),那么該怎么去檢測(cè)出的包究竟有沒(méi)有將SwiftUI.framework改為可選呢?
我嘗試使用 otool -L 命令將IPA里面的可執(zhí)行文件的庫(kù)引入進(jìn)行比對(duì)。
以下是會(huì)崩潰的IPA包分析結(jié)果(部分):

/System/Library/Frameworks/SwiftUI.framework/SwiftUI (compatibility version 0.0.0, current version 0.0.0)
.......(省略)
@rpath/libswiftUIKit.dylib (compatibility version 1.0.0, current version 5504.0.0, weak) 
.......(省略)

以下是修改后沒(méi)問(wèn)題的IPA包分析結(jié)果(部分):

/System/Library/Frameworks/SwiftUI.framework/SwiftUI (compatibility version 0.0.0, current version 0.0.0, weak)
.......(省略)
@rpath/libswiftUIKit.dylib (compatibility version 1.0.0, current version 5100.0.0, weak) 
.......(省略)

/System/Library/Frameworks/SwiftUI.framework/SwiftUI (compatibility version 0.0.0, current version 0.0.0, weak)
很明顯,將SwiftUI.framework改為Optional后會(huì)多個(gè)weak的顯示。
所以,確實(shí)可以通過(guò)【otool -L 可執(zhí)行文件路徑】這個(gè)命令進(jìn)行檢查。SwiftUI.framework一行后面有weak代表已經(jīng)將其設(shè)置成Optional,沒(méi)有那就是沒(méi)有設(shè)置。

參考文章

stackoverflow:dyld: Library not loaded SwiftUI when app runs on iOS 12 using @available(iOS 13.0, *)
https://github.com/firebase/firebase-ios-sdk/releases
https://firebase.google.com/support/release-notes/ios
蘋(píng)果開(kāi)發(fā)者論壇:dyld: Library not loaded: /System/Library/Frameworks/SwiftUI.framework/SwiftUI
掘金:Xcode version 13.2 & 13.2.1 在iOS12上 由libswift_Concurrency.dylib 引起的crash修復(fù)

最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請(qǐng)聯(lián)系作者
【社區(qū)內(nèi)容提示】社區(qū)部分內(nèi)容疑似由AI輔助生成,瀏覽時(shí)請(qǐng)結(jié)合常識(shí)與多方信息審慎甄別。
平臺(tái)聲明:文章內(nèi)容(如有圖片或視頻亦包括在內(nèi))由作者上傳并發(fā)布,文章內(nèi)容僅代表作者本人觀點(diǎn),簡(jiǎn)書(shū)系信息發(fā)布平臺(tái),僅提供信息存儲(chǔ)服務(wù)。

相關(guān)閱讀更多精彩內(nèi)容

友情鏈接更多精彩內(nèi)容