iOS18系统 [YYKVStorage _dbClose] 偶现崩溃

一. 背景

项目线上会偶现[YYKVStorage _dbClose]的相关崩溃问题,崩溃堆栈如下:

二. 分析与治理

通过分析代码,这个崩溃发生在App应用退出的时候,YYDiskCache会调用_appWillBeTerminated,将YYKVStorage置为nil,接着YYKVStorage会调用dealloc方法,最后调用[YYKVStorage _dbClose],在调用sqlite3_close的时候出现了崩溃。

第一次治理

一开始从YYCachegithub上面发现,线上也有反馈过类似的问题

github.com/ibireme/YYC...

因此采用了这里的治理方法,但上线后依然存在着result = sqlite3_close(_db);崩溃问题。

第二次治理

因为崩溃是EXC_BAD_ACCESS (SIGSEGV)类型,觉得可能是多线程导致的野指针问题。

从代码里面排查YYDiskCache里面的YYKVStorage *_kv;基本所有的操作都添加了锁操作。

只有极少数的读取操作没有添加锁操作。

因此调整了加锁的范围

但上线之后,也依然存在这个崩溃问题,显然也不是这里引起的。

第三次治理

因为前两次治理都没有解决这个问题,依据AI和网上给的一些建议是替换sqlite3_close函数,替换为sqlite3_close_v2,并且去掉当关闭状态为result == SQLITE_BUSY || result == SQLITE_LOCKED时候的重试逻辑。

该方案上线之后,也依然存在这个崩溃。

第四次治理

因为崩溃基本全是出现在iOS18的系统,结合DeepSeek以及一些文章给得的结论,有部分文章说iOS18在应用程序退出时候,系统会对sqlite3进行关闭回收操作,而YYCache内部在应用即将退出UIApplicationWillTerminateNotification的时候,会主动调用一次关闭,导致了关闭的时候,刚好系统关闭回收了sqlite3,因此出现野指针。我们观察其他三方比如神策里面sqlite3的使用逻辑,并没有在应用即将退出的时候调用关闭sqlite3的操作。

针对这个添加了降级方案,在iOS18及以上的系统,当UIApplicationWillTerminateNotification的时候,就不去调用_kv = nil的操作,上线后,经验证,这个崩溃确实没出现。由于sqlite3没有调用close,但操作系统会帮忙回收,因此下次启动,打开也是正常的。

相关推荐
初级代码游戏3 小时前
iOS开发 SwiftUI 14:ScrollView 滚动视图
ios·swiftui·swift
初级代码游戏5 小时前
iOS开发 SwitftUI 13:提示、弹窗、上下文菜单
ios·swiftui·swift·弹窗·消息框
zhyongrui8 小时前
托盘删除手势与引导体验修复:滚动冲突、画布消失动画、气泡边框
ios·性能优化·swiftui·swift
Boxsc_midnight11 小时前
【openclaw+imessage】【免费无限流量】集成方案,支持iphone手机+macos
ios·智能手机·iphone
感谢地心引力21 小时前
安卓、苹果手机无线投屏到Windows
android·windows·ios·智能手机·安卓·苹果·投屏
2501_915918411 天前
HTTPS 代理失效,启用双向认证(mTLS)的 iOS 应用网络怎么抓包调试
android·网络·ios·小程序·https·uni-app·iphone
Swift社区1 天前
Flutter 路由系统,对比 RN / Web / iOS 有什么本质不同?
前端·flutter·ios
zhyongrui1 天前
SnipTrip 发热优化实战:从 60Hz 到 30Hz 的性能之旅
ios·swiftui·swift
Andy Dennis1 天前
ios开发 xcode配置
ios·cocoa·xcode
JoyCong19981 天前
iOS 27 六大功能前瞻:折叠屏、AI Siri与“雪豹式”流畅体验,搭配ToDesk开启跨设备新协作
人工智能·ios·cocoa