iOS 性能优化实践:头条抖音如何实现 OOM 崩溃率下降50%+
https://juejin.cn/post/6885144933997494280
从 OOM 到 iOS 内存管理 | 创作者训练营:
讲述 iOS Foreground Out-Of-Memory (FOOM) 和 Background Out-Of-Memory (BOOM) 两种超出内存限制的 OOM 崩溃 以及苹果的Jetsam 机制
如何确认iOS内存崩溃阀值
https://www.mdeditor.tw/pl/glr6
1,Jetsam 日志
rpages * pageSize 1.4G
2,
别人测试出来的网络数据
https://stackoverflow.com/questions/5887248/ios-app-maximum-memory-budget/15200855#15200855
iPad1: 127MB/256MB/49%
iPad2: 275MB/512MB/53%
iPad3: 645MB/1024MB/62%
iPad4: 585MB/1024MB/57% (iOS 8.1)
iPad Mini 1st Generation: 297MB/512MB/58%
iPad Mini retina: 696MB/1024MB/68% (iOS 7.1)
iPad Air: 697MB/1024MB/68%
iPad Air 2: 1383MB/2048MB/68% (iOS 10.2.1)
iPad Pro 9.7": 1395MB/1971MB/71% (iOS 10.0.2 (14A456))
iPad Pro 10.5”: 3057/4000/76% (iOS 11 beta4)
iPad Pro 12.9” (2015): 3058/3999/76% (iOS 11.2.1)
iPad Pro 12.9” (2017): 3057/3974/77% (iOS 11 beta4)
iPad Pro 11.0” (2018): 2858/3769/76% (iOS 12.1)
iPad Pro 12.9” (2018, 1TB): 4598/5650/81% (iOS 12.1)
iPad 10.2: 1844/2998/62% (iOS 13.2.3)
iPod touch 4th gen: 130MB/256MB/51% (iOS 6.1.1)
iPod touch 5th gen: 286MB/512MB/56% (iOS 7.0)
iPhone4: 325MB/512MB/63%
iPhone4s: 286MB/512MB/56%
iPhone5: 645MB/1024MB/62%
iPhone5s: 646MB/1024MB/63%
iPhone6: 645MB/1024MB/62% (iOS 8.x)
iPhone6+: 645MB/1024MB/62% (iOS 8.x)
iPhone6s: 1396MB/2048MB/68% (iOS 9.2)
iPhone6s+: 1392MB/2048MB/68% (iOS 10.2.1)
iPhoneSE: 1395MB/2048MB/69% (iOS 9.3)
iPhone7: 1395/2048MB/68% (iOS 10.2)
iPhone7+: 2040MB/3072MB/66% (iOS 10.2.1)
iPhone8: 1364/1990MB/70% (iOS 12.1)
iPhone X: 1392/2785/50% (iOS 11.2.1)
iPhone XS: 2040/3754/54% (iOS 12.1)
iPhone XS Max: 2039/3735/55% (iOS 12.1)
iPhone XR: 1792/2813/63% (iOS 12.1)
iPhone 11: 2068/3844/54% (iOS 13.1.3)
iPhone 11 Pro Max: 2067/3740/55% (iOS 13.2.3)
3,
基于 Split 工具 获取的 Jaspers 列表
设备 RAM 阈值范围(百分制)
256MB 49% - 51%
512MB 53% - 63%
1024MB 57% - 68%
2048MB 68% - 69%
3072MB 63% - 66%
4096MB 77%
6144MB 81%
特别的案例:
设备 RAM 阈值范围(百分制)
iPhone X (3072MB) 50%
iPhone XS/XS Max (4096MB) 55%
iPhone XR (3072MB) 63%
iPhone 11/11 Pro Max (4096MB) 54% - 55%
1GB设备 安全阈值 45%,2-3GB 设备安全阈值 50% 4GB设备安全阈值 55%。
ios崩溃报告如何读懂(一)
https://mp.weixin.qq.com/s?__biz=MzU1MzUzOTk0Ng==&mid=2247483791&idx=1&sn=beace4bd9926c0b34176a493c4ca001a&chksm=fbf0018acc87889c42bb1f69748b090bdf668e5938c75caccc21952789b3f2263cb8a29e98e7&token=185545398&lang=zh_CN#rd
ios崩溃报告如何读懂(二)
https://mp.weixin.qq.com/s?__biz=MzU1MzUzOTk0Ng==&mid=2247483905&idx=1&sn=c67256febdf1616ff04cadceaa55ca2d&chksm=fbf00204cc878b1230f0c3ad129bd8c8f554470baa6b3ced157349c3c0306f7ab3e5e2bc5117&token=185545398&lang=zh_CN#rd
Jetsam是 iOS 操作系统为了控制内存资源过度使用而采用的一种资源管控机制。不同于MacOS,Linux,Windows等桌面操作系统,出于性能方面的考虑,iOS 系统并没有设计内存交换空间的机制,所以在 iOS 中,如果设备整体内存紧张的话,系统只能将一些优先级不高或占用内存过大的进程直接终止掉。
Jetsam机制清理策略可以总结为下面两点:
单个 App 物理内存占用超过上限
整个设备物理内存占用收到压力按照下面优先级完成清理:
后台应用>前台应用
内存占用高的应用>内存占用低的应用
用户应用>系统应用
rpages:是resident pages的缩写,表明进程当前占用的内存页数量,Heimdallr-Example 这个应用占用的内存页数量是 92800,基于 pageSize 和 rpages 可以计算出应用崩溃时占用的内存大小:16384 * 92800 / 1024 /1024 = 1.4GB。
出于性能方面的考虑,iOS 系统并没有设计内存交换空间的机制,所以在 iOS 中,如果设备整体内存紧张的话,系统只能将一些优先级不高或占用内存过大的进程直接终止掉。
iOS 不支持交换空间,并且大多数移动设备都不支持交换空间。移动设备的大容量内存通常是闪存,它的读写速度远远小于计算机使用的硬盘,这导致即使移动设备上使用了交换空间,也无法提高性能。其次,移动设备本身容量往往不足,内存的读写寿命也有限,在这种情况下,使用闪存进行内存交换有点奢侈。
页面永远不会被调出到磁盘,但是只读页面仍然可以根据需要从磁盘调出。
综上所叙;
2个问题不太明白:
1、iOS 不支持交换空间。
2、阀值是1.4G还是Jaspers 列表值或者真机测试跑出来的值