V2EX = way to explore
V2EX 是一个关于分享和探索的地方
现在注册
已注册用户请  登录
iOS 开发实用技术导航
NSHipster 中文版
http://nshipster.cn/
cocos2d 开源 2D 游戏引擎
http://www.cocos2d-iphone.org/
CocoaPods
http://cocoapods.org/
Google Analytics for Mobile 统计解决方案
http://code.google.com/mobile/analytics/
WWDC
https://developer.apple.com/wwdc/
Design Guides and Resources
https://developer.apple.com/design/
Transcripts of WWDC sessions
http://asciiwwdc.com
Cocoa with Love
http://cocoawithlove.com/
Cocoa Dev Central
http://cocoadevcentral.com/
NSHipster
http://nshipster.com/
Style Guides
Google Objective-C Style Guide
NYTimes Objective-C Style Guide
Useful Tools and Services
Charles Web Debugging Proxy
Smore
Sponsored by
LinkedIn
不坐班的神仙工作 · 去任何你想去的地方远程,赚一线城市的工资
2000 个不用出门 Social 的全球远程工作,帮助 V2EX 的小伙伴开启全新的工作方式。
Promoted by LinkedIn
ChrisFreeMan
V2EX  ›  iDev

SwiftUI Image View 内存占用的一个坑...顺便求下解决办法

  •  
  •   ChrisFreeMan · 81 天前 · 4891 次点击
    这是一个创建于 81 天前的主题,其中的信息可能已经有所发展或是发生改变。

    我之前开发的一个应用发现了不太正常的内存占用,整个应用说不上数据结构有多复杂,但是内存占用就是很高,觉得很离谱,后来网上翻了下,发现 Image View 渲染的内存占用是和文件大小没有关系,是和像素有关系的,一个像素大约占用 4 个字节,假如我有一张图片 2400 * 1600 大小,2400 * 1600 * 4 就是约等于 15MB 的样子,我一个侧边栏菜单一共要渲染 12 张图片就要占用 180 MB ,遭不住,有没有优雅一点的解决办法😂

    14 条回复    2022-07-07 11:17:53 +08:00
    xfriday
        1
    xfriday  
       81 天前
    制作 icon 小图就好了,或者用矢量图
    kera0a
        2
    kera0a  
       81 天前
    图片文件大小都是经过压缩后的大小,实际显示都是要解压的。
    你应该裁剪下图片大小让图片符合 ImageView 的大小,你显示在侧边栏不需要用这么大尺寸的图片。
    yfugibr
        3
    yfugibr  
       81 天前 via Android
    侧边栏菜单为什么会用到 2400x1600 的图片?用户的屏幕分辨率已经达到 40k 了吗
    ChrisFreeMan
        4
    ChrisFreeMan  
    OP
       81 天前
    @kera0a
    @yfugibr 偷懒做法,懒得裁图,我以为 resize 会帮助压缩图片的
    @xfriday 实在没办法我只能做小图了
    kera0a
        5
    kera0a  
       81 天前 via iPhone
    @ChrisFreeMan 你运行时 resize 了还占用内存可能是原图被缓存了,你搜一下怎么释放或者避免加载图片时自动缓存。最简单还是提前裁好
    ChrisFreeMan
        6
    ChrisFreeMan  
    OP
       81 天前
    @kera0a 好的,多谢,我先把图裁好吧,后面再研究一下。
    codeisjobs
        7
    codeisjobs  
       81 天前
    url 图片多大,实际展示时需要将图片解压成实际大小的数据,会大很多。所以千万不能直接用原图,不然内存真撑不住。
    ChrisFreeMan
        8
    ChrisFreeMan  
    OP
       81 天前
    @codeisjobs 长记性了😂
    okakuyang
        9
    okakuyang  
       81 天前
    简单点的方法就是用 Nuke/NukeUI 这个库,会自动帮你裁剪图片尺寸,缓存图片。不需要自己去实现这些东西。swiftui 的 resize 只是这个 View 可以被重设大小而已。
    beijiaoff
        10
    beijiaoff  
       81 天前
    并不是人家占内存多,你图片这么大,不占内存才怪。2400 * 1600 都超过屏幕分辨率了,相当于你同时显示 12 个显示器了。
    musi
        11
    musi  
       81 天前
    从性能较角度来说最好就是直接把图片源文件处理掉
    感觉这不是 swiftui 的坑
    因为你如果用 html 的 img 标签去渲染的话还是会遇到同样的问题,在 chrome 上的表现就是有个 decodeImg 的长任务
    上次我直接用相机拍出来的 jpg 照片在网页上渲染就会非常卡,我压缩了一下就很正常了
    ChrisFreeMan
        12
    ChrisFreeMan  
    OP
       81 天前
    @okakuyang
    @beijiaoff
    @musi 非常感谢回复,问题已经解决了,现在又钻进新的问题了😂
    inhons
        13
    inhons  
       81 天前
    居然真的有人不压图片就用啊
    inhons
        14
    inhons  
       81 天前
    我前东家做图片社区的,不压图直接 GG
    关于   ·   帮助文档   ·   API   ·   FAQ   ·   我们的愿景   ·   广告投放   ·   感谢   ·   实用小工具   ·   4204 人在线   最高记录 5497   ·     Select Language
    创意工作者们的社区
    World is powered by solitude
    VERSION: 3.9.8.5 · 41ms · UTC 03:58 · PVG 11:58 · LAX 20:58 · JFK 23:58
    Developed with CodeLauncher
    ♥ Do have faith in what you're doing.