- (UITableViewCell *)tableView:(UITableView *)tableView cellForRowAtIndexPath:(NSIndexPath *)indexPath {

    NSString *aCellID = @"aCellID";
UITableViewCell *cell = [tableView dequeueReusableCellWithIdentifier:aCellID]; if (cell == nil) {
cell = [[UITableViewCell alloc] initWithStyle:UITableViewCellStyleDefault reuseIdentifier:aCellID];
} cell.textLabel.text = [NSString stringWithFormat:@"这是第%tu行", indexPath.row];
return cell;
}
上述的代码非常常见,先定义一个cell的重用标识,然后再从table的池子里根据这个标识去取cell便于重用,如果没有取到cell就创建某种样式这种标识的cell,然后再分发数据给cell。
 
 
一、为什么要设定一个标识,为了cell的复用。如果某些情况下不想重用,那么就没必要创建这个标识,但是不创建标示我们创建cell的时候就只有一个initWithStyle,写个样式,然后加个标识;这样每次来取cell的时候就是直接拿,不用再去池子里取了。假如你的table里就展示三个cell完全适用,也没必要千篇一律地写上面那些代码,为什么写,难道每次都复用,或者我们根本不思考一些问题,直接那样写,我想我不应该是那样的人,也行是闲得蛋疼,有些人总会找些事来做,比如说我,并深知其中快乐。
- (UITableViewCell *)tableView:(UITableView *)tableView cellForRowAtIndexPath:(NSIndexPath *)indexPath {

     NSString *aCellID = @"aCellID";
TableViewCellw *cell = [[TableViewCellw alloc] initWithStyle:UITableViewCellStyleDefault reuseIdentifier:aCellID]; cell.textLabel.text = [NSString stringWithFormat:@"这是第%tu行", indexPath.row];
return cell;
}

既然已经不重用cell了,那么系统也不会再去池子里取了,进而这个标识也没用了,直接置空吧,这样写起代码来更简洁
    
- (UITableViewCell *)tableView:(UITableView *)tableView cellForRowAtIndexPath:(NSIndexPath *)indexPath {

     TableViewCellw *cell  = [[TableViewCellw alloc] initWithStyle:UITableViewCellStyleDefault reuseIdentifier:nil];

    cell.textLabel.text = [NSString stringWithFormat:@"这是第%tu行", indexPath.row];
return cell;
}
这样没从池子里取而是直接创建cell不管你有没有设置重用标识,它都会在自身整个视图超出table时 dealloc。如果是从池子里取的,则出table时会被放到了池子里进行缓存等待下次重用。
 
 
有些时候,可能我们只是需要UITableViewCellStyleDefault这种样式的cell,那么在这种情况下我们的代码还可以写成这样
    
- (UITableViewCell *)tableView:(UITableView *)tableView cellForRowAtIndexPath:(NSIndexPath *)indexPath {

     TableViewCellw *cell  = [[TableViewCellw alloc] init];

    cell.textLabel.text = [NSString stringWithFormat:@"这是第%tu行", indexPath.row];
return cell;
}

当然如果要你不是用的系统默认的样式,则又要把style这个init写出来,这样才能获取需求的样式
    
- (UITableViewCell *)tableView:(UITableView *)tableView cellForRowAtIndexPath:(NSIndexPath *)indexPath {

     TableViewCellw *cell  = [[TableViewCellw alloc] initWithStyle:UITableViewCellStyleValue1 reuseIdentifier:nil];

    cell.textLabel.text = [NSString stringWithFormat:@"这是第%tu行", indexPath.row];
return cell;
}
需要注意的是上面的做法只适合于不需要重用的情况。一个talbe就用三四个cell展示一点数据,完全没必要写那些重用的代码。
就像公司到底是用纯代码,xib加代码还storyboard加代码来开发一样,根据需求怎样简单怎样选择开发方式。
有些公司一直坚持用纯代码开发,总是觉得有xib有storyboard,总觉得他们是xml格式的,到时运行或者其他什么的转化需要时间,可能会影响到性能。
 
其实经过编译然后链接再运行的时候,或者你解包一个app就能看到一些文件,或者你也像我一样学过汇编,知道到最底层的时候都是01串了,苹果打包时,已经把它们弄成01串了。就算真的影响性能,苹果这个这么注重性能优化的公司会允许我们大用xib,storyboard吗。
 
之前见一哥们的公司就用stroryboard开发,而且到了跟iOS开发中比单例还滥用的几百倍的感觉,猛地打开storyboard卡地我电脑,还以为pro不给力了,结果打开才发现好几百个控制器在里面,线飞来飞去地,整个银河系统星云尘埃联运的感觉……
 
二、为什么要从池子里取,这是table的默认的重用机制,里面放着某种标识的cell,等待提取等待复用,之前尝试让table不重用,无奈技术不到位。
 
 
三、为什么要判断cell为空,cell为空也就是没从池子里取到这种标识的cell。
 
不是每次cell都可能为空,比如你在storyboard里有cell并且设定了标识,那么就没必要判断为空的情况了,因为当系统从池子里取时,会有个从storyboard或者是xib里查找这种标识的cell的过程,所以当你非常确定时,就直接从池子里取吧。
 
应该是先看看storyboard中有没有这种标识的cell,所以如果你在storyboard中有了这个标识的cell,那么就不用判断为空了,直接系统每次就能在空的情况下在storyboard在拿到一个。所以后面见有些大神的代码更精简了,不过现在好多公司都是xib加代码。
- (UITableViewCell *)tableView:(UITableView *)tableView cellForRowAtIndexPath:(NSIndexPath *)indexPath {

    // 注意这里的标识要跟storyboard或者xib里cell的标识要一样
UITableViewCell *cell = [tableView dequeueReusableCellWithIdentifier:@"aCellID"]; cell.textLabel.text = [NSString stringWithFormat:@"这是第%tu行", indexPath.row];
return cell;
}

说到到底,一开始就是由于cell个数少不想重用,不想写那些常规代码进而对常规代码进行了精简,

其实如果这些为数不多的cell如果在项目中功能需求不复杂的话,完全可以使用静态单元格来实现。

这样在控制器的代码也更简单了,不用写那三个写得快吐了的代理方法了,系统直接从storyboard中取。

修改静态单元格中的数据也简单

关于talbeViewCell一点感想的更多相关文章

  1. 学习javascript 的一点感想

    原文:学习javascript 的一点感想 //动态性是指,在一个Javascript对象中,要为一个属性赋值,我们不必事先创建一个字段,只需要在使用的时候做赋值操作即可,如下例:var obj=ne ...

  2. 关于 Bellman-Ford 与 Floyd 算法的一点感想

    在四种常用的最短路算法 Dijkstra, SPFA, floyd, Bellman-Ford 中, Dijks 和 SPFA 的使用较为普遍, 对大多数人来说, 也较为熟悉. 然而, floyd 与 ...

  3. 关于header file、static、inline、variable hides的一点感想

    前言 先看一段代码 #ifndef _INLINE_H #define _INLINE_H template<typename T> static inline T my_max(T a, ...

  4. 对torch的一点感想

    torch是一个基于LuaJIT的科学计算框架,知乎上有个人回答说torch比较适合科研用途, torch与matlab的很多函数很相似

  5. 关于litecoin莱特币挖矿、炒作的一点感想

    比特币早在一.二年前我就听说过这个词了,还自己试过搭设矿机,因为没找到显卡驱动,也没有人一起搞,所以中途放弃了. 后来就不断听说涨了多少倍,总想着都涨这么多了,错了也就错过了. 周二组会,一帮人兴起又 ...

  6. Unity3D 新人学习的一点感想

    想到那里写到那里吧 1.Unity3D的优点大家都知道:组件化.c#语言.可见即所得. 当初刚开始学习的是cocos2dx,c++的货,觉得还是写的不错的,也是国人开发的,真的代码很容易懂,直接看引擎 ...

  7. TreePuzzle 一点感想

    题目链接 这一道题看起来像是一道贪心的水题,但是情况较难考虑周全,比如下图,我就考虑漏了这种情况,点0是可以移动到点1的.然后我就各种奇怪的分类讨论.最终还是没能A,决定放弃治疗. 然后我看了看解答, ...

  8. 关于mac地址的一点感想

    因为怕mac地址冲突导致环路影响,所以修改了本地设备的mac地址.地址修改为 77:77:77:00:22:11, 结果导致 wlan0 下发不下来. 查看配置选项/etc/config/wirele ...

  9. 关于学习MMU的一点感想

    MMU的一个主要服务是能把各个人物作为各自独立的程序在其自己的虚拟存储空间中运行. 虚拟存储器系统的一个重要特征是地址重定位.地址重定位是将处理器核产生的地址转换到主存的不同地址,转换由MMU硬件完成 ...

随机推荐

  1. select、poll、epoll程序实例

    三个函数的基本用法如下: select 创建 fd_set rset , allset; FD_ZERO(&allset); FD_SET(listenfd, &allset); 监听 ...

  2. JS 之性能优化(2)

    继续上一篇的JS性能优化之后,下面接着讲关于前端性能优化的内容.如果有不对的地方欢迎纠正. 1.避免过多的重排与重绘操作. 尽量将DOM中的多个读操作放一起,中间不要插入写的操作,因为写操作会导致浏览 ...

  3. vector 内存释放问题

    关于容器的处理,只是拿来用,理解不深,但是今天跑程序出了问题.释放空间未得到真正的释放.于是网上找了一些文章,解决的问题. 解决方法:使用swap 加上clear,一起释放空间. 原理:即先创建一个临 ...

  4. MVC采用HtmlHelper扩展和Filter封装验证码的功能

    最近因为有个项目除了登录还有其他很多地方需要用到验证码的功能,所以想到了采用HtmlHelper和ActionFilter封装一个验证码的功能,以便能够重复调用.封装好以后调用很方便,只需在View中 ...

  5. jdbc基础 (五) 连接池与数据源 DBCP以及C3P0的使用

    一.连接池的概念和使用 在实际应用开发中,特别是在WEB应用系统中,如果JSP.Servlet或EJB使用JDBC直接访问数据库中的数据,每一次数据访问请求都必须经历建立数据库连接.打开数据库.存取数 ...

  6. [AHOI2013]找硬币(搜索)

    [Ahoi2013]找硬币 Time Limit: 10 Sec  Memory Limit: 64 MBSubmit: 348  Solved: 114[Submit][Status] Descri ...

  7. Boostrap(3)

    常用标签 1.文字 p标签(段落) small标签(让文字呈现灰色) em标签(文字斜体) blokcquote标签(文字内容为引用时用该标签) class=”pull-right"右浮动 ...

  8. 初探JAVA中I/O流(一)

    一.流 流,这里是对数据交换的形象称法.进程是运行在内存中的,在运行的过程中避免不了会与外界进行数据交互.比如将数据从硬盘.控制台.管道甚至是套接字(具体点应该是我们电脑上的网卡)读到我们进程锁所占据 ...

  9. 11.C#迭代器(六章6.1)

    今天我们说下C#中的迭代器,首先引出一些关于迭代的概念,后面举出代码供大家讨论. 迭代器模式是行为模式的一种范例,行为模式是一种简化对象之间通信的一种设计模式.在.NET中使用IEnumerator和 ...

  10. java文件中文在MyEclipse中打开变成了乱码

    导入其他人的项目,出现乱码状况 以下是解决方案之一: