zoukankan      html  css  js  c++  java
  • imageNamed:与imageWithContentsOfFile:的区别

    Apple官方的文档为生成一个UIImage对象提供了两种方法加载图片:
    1. imageNamed,其参数为图片的名字;
    2. imageWithContentsOfFile,其参数也是图片文件的路径。
    那么两种有什么区别吗?
    肯定是有的。根据Apple的官方文档:
    imageNamed: 这个方法用一个指定的名字在系统缓存中查找并返回一个图片对象如果它存在的话。如果缓存中没有找到相应的图片,这个方法从指定的文档中加载然后缓存并返回这个对象。因此imageNamed的优点是当加载时会缓存图片。所以当图片会频繁的使用时,那么用imageNamed的方法会比较好。例如:你需要在 一个TableView里的TableViewCell里都加载同样一个图标,那么用imageNamed加载图像效率很高。系统会把那个图标Cache到内存,在TableViewCell里每次利用那个图像的时候,只会把图片指针指向同一块内存。正是因此使用imageNamed会缓存图片,即将图片的数据放在内存中,iOS的内存非常珍贵并且在内存消耗过大时,会强制释放内存,即会遇到memory warnings。而在iOS系统里面释放图像的内存是一件比较麻烦的事情,有可能会造成内存泄漏。例如:当一个UIView对象的animationImages是一个装有UIImage对象动态数组NSMutableArray,并进行逐帧动画。当使用imageNamed的方式加载图像到一个动态数组NSMutableArray,这将会很有可能造成内存泄露。原因很显然的。
    imageWithContentsOfFile:仅加载图片,图像数据不会缓存。因此对于较大的图片以及使用情况较少时,那就可以用该方法,降低内存消耗。
    下面列举出两种方法的详细用法:
    NSString *path = [[NSBundle mainBundle] pathForResource:@”icon” ofType:@”png”];
    UIImage *image = [UIImage imageWithContentsOfFile:path];
     
     NSString *filePath = [[NSBundle mainBundle] pathForResource:fileName ofType:“png”];
    UIImage *image = [UIImage imageWithContentsOfFile:filePath];
    //或者
     //NSData *image = [NSData dataWithContentsOfFile:filePath];
     //UIImage *image = [UIImage imageWithData:image]; 


    imageNamed:先将图片缓存到内存中,然后在显示。

    imageWithContentsOfFile:仅加载图片,图像数据不会缓存。


    总得来说,使用大的图片,如果不是常用,那么用 imagewithcontentsoffile 方法,比较小的(比如图标),需要经常使用的,那么用后者,imageNamed 加载,内存常驻,效率高,但是会放在内存里作为cache,图片多了容易导致crash。
  • 相关阅读:
    js转盘游戏
    wps excel
    微软笔记本
    图片识别
    数据库 连接 集
    Vue + Element UI 实现权限管理系统 前端篇(十二):用户管理模块
    Vue + Element UI 实现权限管理系统 前端篇(十三):页面权限控制
    Vue + Element UI 实现权限管理系统 前端篇(十四):菜单功能实现
    Vue + Element UI 实现权限管理系统 前端篇(十五):嵌套外部网页
    Vue + Element UI 实现权限管理系统 前端篇(九):接口格式定义
  • 原文地址:https://www.cnblogs.com/LynnAIQ/p/5937402.html
Copyright © 2011-2022 走看看