UITableView的性能优化整理

为了使APP的性能有一个提高,避免了滑动tableView的时候出现卡顿的效果,同时在开发中tableView使用的频率较高,所以做了一个简单的整理

列出了很多条,有耐心的可以看一看。

一、

 Cell内部控件的层次尽量的少,使用drawRect来画。

二、

 Cell内部所有显示的数据提前准备好,尽量少的进行实时计算。

三、

所有的控件大小提前计算好,不要每一次都计算。

四、

缓存行高: 因为利用自动布局计算行高很消耗CPU,每次滚动Cell都需要再次计算,

self.contentView.layoutIfNeeded; 它的作用就是重新刷新一下控件的布局来重新计算控件的大小。

使用注意: 要移除contentView底部的约束

参考文章

http://www.cocoachina.com/ios/20150803/12873.html

五、

利用CPU异步绘制Cell的layer :

layer.drawAsynchronously。

六、

栅格化:将cell内容渲染成一张图片,在滚动的时候就是一张图片

layer.shouldRasterize;

layer.rasterizationScale;

七、

按需加载:按照用户滚动的速度去选择加载哪个Cell 

//gitHib上的开源项目 有示例demo

https://github.com/johnil/VVeboTableViewDemo

八、

在Cell中不要用layer去画圆角:CALayer的cornerRadius是一个超级废性能的东西,它会在每一帧都裁剪圆角,比如在tableView每个Cell里都有一个裁剪属性,

无论你有没有滚动视图都会运算裁剪圆角,很费CPU性能!

参考文章

http://www.cocoachina.com/ios/20150803/12873.html

解决方法

http://blog.csdn.net/shaobao8910/article/details/46779259

注意: 服务器返回的图片就是圆角的,iOS9之后,imageView中如果显示png图片的话是不需要关心圆角问题的

九、

控件尽量不要使用透明度:因为如果上层控件半透明的话,系统会努力的绘制下层控件的内容与上层控件的内容,并且将两个内容按照透明度去进行绘制


其他方面(尽量的少使用富文本,时间格式化对象使用同一个,列表内部的子控件都要少量的计算)。






  • 1
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
要在UITableView的section中添加数据,你需要先创建一个包含所需数据的数组。然后,在UITableViewDataSource协议中实现以下方法: 1. numberOfSections(in tableView: UITableView) -> Int:返回表格中的section数。 2. tableView(_ tableView: UITableView, numberOfRowsInSection section: Int) -> Int:返回指定section中的行数。 3. tableView(_ tableView: UITableView, cellForRowAt indexPath: IndexPath) -> UITableViewCell:返回指定indexPath的UITableViewCell实例。 例如,假设你有一个包含多个section的UITableView,每个section都包含一个字符串数组。以下是一个示例代码: ``` class ViewController: UIViewController, UITableViewDataSource { var data: [[String]] = [["item 1", "item 2"], ["item 3", "item 4", "item 5"]] @IBOutlet weak var tableView: UITableView! override func viewDidLoad() { super.viewDidLoad() tableView.dataSource = self } // MARK: - UITableViewDataSource func numberOfSections(in tableView: UITableView) -> Int { return data.count } func tableView(_ tableView: UITableView, numberOfRowsInSection section: Int) -> Int { return data[section].count } func tableView(_ tableView: UITableView, cellForRowAt indexPath: IndexPath) -> UITableViewCell { let cell = tableView.dequeueReusableCell(withIdentifier: "Cell", for: indexPath) cell.textLabel?.text = data[indexPath.section][indexPath.row] return cell } } ``` 在这个例子中,我们创建了一个包含两个section的UITableView。每个section都有一个字符串数组,我们将其存储在data数组中。在numberOfSections方法中,我们返回data数组的数量,即section的数量。在tableView(_:numberOfRowsInSection:)方法中,我们返回特定section中的行数。最后,在tableView(_:cellForRowAt:)方法中,我们获取特定indexPath的字符串并将其显示在UITableViewCell中。 注意,在上述示例代码中,我们将UITableViewCell标识符设置为“Cell”,你需要确保在Storyboard或xib文件中对应的UITableViewCell的标识符也设置为“Cell”。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值