Loading [MathJax]/jax/output/CommonHTML/config.js
前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
圈层
工具
发布
首页
学习
活动
专区
圈层
工具
社区首页 >专栏 >iOS TableView 优化

iOS TableView 优化

作者头像
赵哥窟
发布于 2021-05-19 06:29:36
发布于 2021-05-19 06:29:36
7880
举报
文章被收录于专栏:日常技术分享日常技术分享

GitHub在看了WeChat ,只提取了朋友圈的代码写了一个Demo。代码很简单。

如果想深入了解,可以参考iOS 保持界面流畅的技巧这篇文章写得很非常好。

优化就注意几点

1.TableView性能影响最大的是每个cell高度的获heightForRowAtIndexPath,这个函数会调用很多次,对于不是固定高度的cell,每次都需要去计算。像朋友圈这种,内容框的高度是需要通过计算文字得到高度的,这种大量的操作是很损耗性能的。所以,在请求完数据之后就计算好每个cell的高度,并且缓存起来,下次直接从缓存拿过来用。

2.使用一些高性能的组件比YY系列YYAnimatedImageView,YYLabel

3.可以把消耗性能的操作放到子线程中执行,不要阻塞主线程。 UIKit的工作基本上都是在主线程上进行,界面绘制,用户输入响应等等。所以当所有的代码逻辑都放在主线程时,某些耗时任务可能会卡住主线程造成程序无法响应,流畅度降低等问题;所以网络请求,cell高度计算,布局计算可以放在子线程执行。

4.尽可能的降低Storyboard,Xib的使用 在网上的一些资料了解到,xib或者storyboard本身就是一个xml文件,添加删除控件必然中间多了一个encode/decode过程,增加了cpu的计算量。Xib文件是在主线程中进行加载布局,所以Cell最好使用纯代码布局。如果cell高度是固定这种情况可以少量使用Xib。

5.滑动过程中尽量减少重新布局 自动布局就是给控件添加约束,约束最终还是转换成frame。所以在满足业务需求情况下,如果view布局层次较为复杂,尽量减少自动布局约束,转为手动计算布局,大量的约束重叠也会增加cpu的计算量

6.调试的时候可以借助监测TPS的工具 一般滚动的时候TPS<=60滚动都很流畅。(这个监测工具Demo里面有),也可以通过Xcode自带的调试工具Instruments来看看界面的流畅度。

7.其实做到上面几点基本就解决问题。至于什么按需加载看情况需不需要优化。

本文参与 腾讯云自媒体同步曝光计划,分享自作者个人站点/博客。
如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 作者个人站点/博客 前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体同步曝光计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
暂无评论
推荐阅读
编辑精选文章
换一批
iOS TableView 优化二
之前写过一篇关于朋友圈的TableView优化。 iOS TableView 优化
赵哥窟
2021/06/01
6030
iOS TableView 优化二
iOS AutoLayout全解
AutoLayout简介 Autolayout是一种全新的布局技术,专门用来布局UI界面的,用来取代Frame布局在遇见屏幕尺寸多重多样的问题。Autolayout自iOS 6开始引入, 但是由于X
xiangzhihong
2018/02/06
4.7K0
iOS AutoLayout全解
iOS 性能优化
为了解释这个问题首先需要了解一下屏幕图像的显示原理。首先从 CRT 显示器原理说起,如下图所示。CRT 的电子枪从上到下逐行扫描,扫描完成后显示器就呈现一帧画面。然后电子枪回到初始位置进行下一次扫描。为了同步显示器的显示过程和系统的视频控制器,显示器会用硬件时钟产生一系列的定时信号。当电子枪换行进行扫描时,显示器会发出一个水平同步信号(horizonal synchronization),简称 HSync;而当一帧画面绘制完成后,电子枪回复到原位,准备画下一帧前,显示器会发出一个垂直同步信号(vertical synchronization),简称 VSync。显示器通常以固定频率进行刷新,这个刷新率就是 VSync 信号产生的频率。虽然现在的显示器基本都是液晶显示屏了,但其原理基本一致。
赵哥窟
2020/06/29
2.9K1
iOS开发中行高灵活可变的UITableView的性能优化
        在新闻类,电商类等应用中,应用着大量的图文混排视图,在表视图UITableView中,开发者通常需要在如下代理方法中计算出当前cell填充内容后的高度,之后将其返回:
珲少
2018/08/15
2K0
iOS开发中行高灵活可变的UITableView的性能优化
iOS开发之多种Cell高度自适应实现方案的UI流畅度分析
本篇博客的主题是关于UI操作流畅度优化的一篇博客,我们以TableView中填充多个根据内容自适应高度的Cell来作为本篇博客的使用场景。当然Cell高度的自适应网上的解决方案是铺天盖地呢,今天我们的重点不是如何讨论Cell高度的自适应,而是给出几种Cell高度自适应的解决方案,然后对比起UI流畅度,从而得出一些UI优化的一些常规做法。今天博客中主要用涉及的第三方库是YYKit和AsyncDisplayKit。 关于YYKit和AsyncDisplayKit这两个库,本篇博客只是简单的涉及到一些基本用法,主
lizelu
2018/01/11
1.7K0
iOS开发之多种Cell高度自适应实现方案的UI流畅度分析
有了Auto Layout,为什么你还是害怕写UITabelView的自适应布局?
本文介绍了一种使用Auto Layout、UITableView-FDTemplateLayoutCell以及Masonry结合使用的实践方案,来解决UITableView中cell高度计算的问题。通过Auto Layout让cell自适应视图大小,使用UITableView-FDTemplateLayoutCell自定义单元格布局,再结合Masonry对cell进行布局约束,从而让UITableView的cell高度完全自适应,以解决UITableView中cell高度计算的问题。
ios122
2018/01/02
9630
有了Auto Layout,为什么你还是害怕写UITabelView的自适应布局?
六天完成一个简单iOS App - 第五天
第五天任务 今天主要完成精华页面中cell内内容的处理。 cell高度的计算 cell中间内容的显示 精华模块的重构 查看图片 保存图片到相册 cell高度的计算 cell间距的设置,每个cell之间有10的间距,因为cell的重用机制,我们发现即使在tableView :didDeselectRowAtIndexPath方法中通过点击cell,减少cell的高度,当cell重新显示的时候还是会变回原来的高度,并且系统内部对cell进行了一些处理,已经在内部设置好cell的frame,所以我们通过重写cel
xx_Cc
2018/05/10
9090
浅汇-iOS UI布局
  iOS中UI的布局是很重要的,而在前期开发中就要选定好布局的方法,因为这对整个工程乃至于后期的版本维护都有很重要的影响。本文从比较老的Frame到新生AutoLayout都进行了浅显的总结,希望对大家的UI布局学习有所帮助
進无尽
2018/09/12
2.2K0
浅汇-iOS UI布局
iOS 优化界面流畅的技巧
对象的创建会分配内存、调整属性、甚至还有读取文件等操作,比较消耗 CPU 资源。尽量用轻量的对象代替重量的对象,可以对性能有所优化。比如 CALayer 比 UIView 要轻量许多,那么不需要响应触摸事件的控件,用 CALayer 显示会更加合适。如果对象不涉及 UI 操作,则尽量放到后台线程去创建,但可惜的是包含有 CALayer 的控件,都只能在主线程创建和操作。通过 Storyboard 创建视图对象时,其资源消耗会比直接通过代码创建对象要大非常多,在性能敏感的界面里,Storyboard 并不是一个好的技术选择。
用户2491699
2018/08/02
1.5K0
iOS面试题梳理(三)
在某个方法中 self.name = _name,name = _name 它 们有区别吗,为什么? 1.前者是存在内存管理的setter方法赋值,它会对_name对象进行保留或者拷贝操作,后者是普
Jacklin
2018/05/15
1.4K0
RunLoop总结:RunLoop的应用场景(三)滚动视图流畅性优化
今天要讲的RunLoop的应用场景可能太简单了,所以东西比较少。因为跟UITableView、UICollectionView等的滑动优化有关,就顺便总结一下会影响UITableView、UICollectionView等视图滑动流畅的因素。
Haley_Wong
2018/08/22
2.3K0
RunLoop总结:RunLoop的应用场景(三)滚动视图流畅性优化
[iOS]创建界面方法的讨论
以前在入门的时候,找的入门书籍上编写的 demo 都是基于 Storyboards 拖界面的。后来接触公司项目,发现界面都是用纯代码去写复杂的 autoLayout 的。再然后,领导给我发了个 Masonry 库去看,依然是手写代码布局界面,但效率高了不少。工作一段时间,看了很多博客,也看了一些书,发现用纯代码写界面的很少,于是就在 Google 上搜 Storyboards 有什么好处,最后发现了一篇非常好的文章。在此提炼文章的一些观点,同时表达一下自己的观点。
wOw
2018/09/18
7750
iOS 9 Storyboard 教程(一下)
你可以直接从storyboard编辑器中,使用原型cell你可以很容易的为你的tableViewCell设计一套自定义的布局.
hrscy
2018/08/30
3.1K0
iOS 9 Storyboard 教程(一下)
iOS性能优化系列篇之“列表流畅度优化”
这一篇文章是iOS性能优化系列文章的的第二篇,主要内容是关于列表流畅度的优化。在具体内容的阐述过程中会结合性能优化的总体原则进行阐述,所以建议大家在阅读这篇文章前先阅读一下上一篇文章:iOS性能优化系列篇之“优化总体原则”。
iOSSir
2019/05/28
2.6K0
【IOS开发基础系列】Table View开发专题
    A table view is an instance of theUITableView class in one of two basic styles, plain or grouped. A plain table view is an unbroken list; a grouped table view has visually distinct sections. A table view has a data source and might have a delegate. The data source object provides the data for populating the sections and rows of the table view. The delegate object customizes its appearance and behavior.
江中散人_Jun
2023/10/16
4790
【IOS开发基础系列】Table View开发专题
iOS中Cell约束--使用xib实现多label的自动约束--高度随内容自适应
made in 小蠢驴的配图        说起iOS开发,很多人的印象就是-弄一个tableView,把数据全丢到上面展示,听起来好像很粗糙,不过仔细一想,确实展示数据内容的,用的tableView是最多的了吧,说到这里,今天的男一号-tableViewCell就要登场了。       本文的主题是--tableViewCell的高度自适应,计算cell高度的方法确实有好几种,因为做cell的时候,比较简单的界面我都是直接拉xib,手动连接约束比较省事,所以今天就来探索一波-- 使用xib实现cell高度
小蠢驴打代码
2018/05/24
3.6K0
iOS表视图单元格高度自适应
iOS表视图高度自适应可以节省很多麻烦,尤其是涉及到复杂的业务逻辑时,今天尝试了使用Masonry和FDTemplatelayoutCell来布局表视图单元格,从而达到单元格高度自适应的效果,这里就总
梧雨北辰
2018/04/24
1.9K0
iOS表视图单元格高度自适应
iOS 布局进阶:你真的会用 autolayout 么?
iOS系统已经迎来了10.3.2版本,iOS软件开发发展至今已经相当成熟了。布局的方式从frame、size、center到如今强大的autolayout,将UI布局尽量的“自动化”和“智能化”,在很大程度上减少了程序员的工作量。
波儿菜
2018/05/07
1.6K0
iOS 布局进阶:你真的会用 autolayout 么?
iOS-UI控件之UITableView(三)- 自定义不等高的cell
Storyboard_不等高 对比自定义等高cell,需要几个额外的步骤(iOS8开始才支持) 添加子控件和contentView之间的间距约束 设置tableViewCell的真实行高和估算行高 // 告诉tableView所有cell的真实高度是自动计算(根据设置的约束来计算) self.tableView.rowHeight = UITableViewAutomaticDimension; // 告诉tableView所有cell的估算高度 self.tableView.estimated
用户1941540
2018/05/11
8950
iOS 如何监测 FPS
现在如果在网络上搜的话,基本上大多数用于检测FPS的控件都是通过 CADisplayLink 来实现的。
网罗开发
2021/11/30
2.1K0
iOS 如何监测 FPS
相关推荐
iOS TableView 优化二
更多 >
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档