Swift 懒加载(lazy) 和 Objective-C 懒加载的区别
来源:互联网 发布:wacc的算法 编辑:程序博客网 时间:2024/05/22 04:35
在程序设计中,我们经常会使用 懒加载
,顾名思义,就是用到的时候再开辟空间,比如iOS开发中的最常用控件UITableView
,实现数据源方法的时候,通常我们都会这样写
Objective-C
- (NSInteger)tableView:(UITableView *)tableView numberOfRowsInSection:(NSInteger)section{ return self.dataArray.count;}- (UITableViewCell *)tableView:(UITableView *)tableView cellForRowAtIndexPath:(NSIndexPath *)indexPath{ //1.得到cell XWShopCell *cell = [XWShopCell cellWithTableView:tableView]; //2.传递模型 cell.wine = self.dataArray[indexPath.row]; //3.回传cell return cell;}
上面的的代码中
return self.dataArray.count;
其实就是利用
@property (nonatomic, strong) NSArray *dataArray;
@property
的特性,为属性生成了get
和set
方法,而这里是调用的get
方法,但是上述代码中return self.dataArray.count
会调用
- (NSArray *)dataArray{ return _dataArray}
这样调用,如果成员属性dataArray 开始没有赋值的,那么在使用的时候,调用get方法,不重写的话,会报错,空指针,所以一般我们会重写get方法
//重写get方法- (NSArray *)dataArray{ if (nil == _dataArray){ _dataArray = [NSArray array]; } return _dataArray}
这样写,就防止了成员属性为没有赋值的情况
综上所述,Objective-C的懒加载,其实就是调用成员属性的get方法,初始化值,而Swift的懒加载,是和Objective-C不同的
Swift
//MARK tablview的 dataSource 代理方法 func tableView(tableView: UITableView, numberOfRowsInSection section: Int) -> Int{ return self.dataArray.count } func tableView(tableView: UITableView, cellForRowAtIndexPath indexPath: NSIndexPath) -> UITableViewCell{ //1.得到cell let cell = XWShopCell.cellWithTableView(tableView) //2.传递模型 cell.wine = self.dataArray[indexPath.row] //3.回传cell return cell }
而这句
return self.dataArray.count
在Swift
存储属性必须初始化,确认类型,或者用可选类型,总之要确认类型,毕竟Swfi
t是类型安全语言,所以Swift
提出了lazy
属性,用法
//1.分析 NSArray 是一个闭包的返回值,而这是一个没有参数的闭包 lazy var dataArray:NSArray = { [] }() //2.也可以写成这样 lazy var dataArray:NSArray = { return NSArray() }() //3.从plist文件加载 lazy var dataArray:Array<XWWine> = { let winePath = NSBundle.mainBundle().pathForResource("wine.plist", ofType: nil)! let winesM = NSMutableArray(contentsOfFile: winePath); var tmpArray:Array<XWWine>! = [] for tmpWineDict in winesM! { var wine:XWWine = XWWine.wineWithDict(tmpWineDict as! NSDictionary) tmpArray.append(wine) } print("我就运行一次") return tmpArray }()
上述的代码,有点难理解,如果之前会Objective-C
的block
或者对C语言
的函数指针理解透彻的,可以看成是一个代码块,然后self.dataArray
的时候,就执行了代码块,但是重复调用,Lazy
属性的代码块只会调用一次,lazy
修饰的是一个存储属性,而存放的是闭包,我想内部,应该进行了优化
个人愚见,内部有一个静态的存储空间,当空间没值的时候,就会执行闭包代码,return
返回值后,就会放到这个存储空间内,有点像Objective-C的单例对象
.
0 0
- Swift 懒加载(lazy) 和 Objective-C 懒加载的区别
- Swift 懒加载(lazy) 和 Objective-C 懒加载的区别
- Swift 懒加载(lazy)
- swift lazy 懒加载
- Swift- lazy 懒加载
- Swift下的Lazy懒加载模式
- swift_043(Swift 懒加载(lazy) )
- Swift中的懒加载—@lazy
- FetchType.LAZY和FetchType.EAGER什么区别?(懒加载和急加载的理解)
- 对比分析Objective_C和Swift懒加载的区别
- 013--swift计算型属性和懒加载的区别
- Hibernate 懒加载lazy
- ruby 懒加载 lazy
- Swift的lazy关键字–延迟加载
- swift学习日志—— lazy懒加载
- swift 3.0 UITableView 懒加载写法(lazy)
- lazy(懒加载)模式和异步加载模式详解
- 图片的懒加载lazy-load.js
- HDU 5723 Abandoned country(DFS+kruskal)
- Cocos2dx 3.0 过渡篇(八)浅谈容器Vector
- js中new一个函数的时候,到底发生了什么
- 如何在OS X中恢复被误删除的文件
- Cocos2d-x 3.0正式版中的数组改为容器
- Swift 懒加载(lazy) 和 Objective-C 懒加载的区别
- kohana ORM用法
- Homework--数组冒泡排序
- Codeforces #363 (Div.2) A. Launch of Collider【水题】
- Codeforces #363(Div.2)B. One Bomb【思维】
- Raspbian常见指令笔记
- 程序猿专用代码注释:佛祖保佑,永无BUG
- web前端主要学什么?
- 成吨提高开发效率:Intellij Shortcuts精简子集与思维模式