iPhone应用:Sqlite和UITableView实现大数据浏览案例

Crazyzihao 2011-08-19

iPhone应用中关于SqliteUITableView实现大数据浏览案例分析是本文要介绍的内容,主要是来学习iphone应用数据处理的操作,具体内容来看本文详细讲解。在开始学习iPhone开发的时候就捉摸 AppStore这样的程序时怎么实现的, 动态的从服务器抓取内容,再在表格中显示。

伴随着twitter的火爆, 越来越多的软件实现了此种方式来显示twitter消息, 不巧公司也要做twitter相关的东西,正好借此机会试探着实现一下这种显示功能。

iPhone应用程序和传统的桌面程序的最大不同在于内存有限, 管理内存成了iPhone开发中时时刻刻需要谨记的事情。类似的功能在桌面程序上无非是将down下来的数据缓存于内存中,需要的时候画出来即可。 此法在iPhone上切不可行,虽然UITableViewCell可与reuse重复使用以节约内存使用量, 但是数据还是需要host在array或者dictionary中,必然导致程序实用大量内存儿崩溃退出。

还好,iPhone系统内置sqlite微型数据库, 这么好的查询插入引擎不善用那就是罪过了。

言归正传, 基本思路是这样的: 从服务器读取内容,以twitter为例,先创建消息数据表

create table public_timelines (id integer primary key autoincrement, user varchar(40),  


userurl text,body text, created real, created_string text,  


imageurl text, ordernum int, userid varchar(20), user_screenname varchar(40)); 

获取public timelines得到以xml形式存在的message条目,解析xml后将每条消息插入数据表, 写入成功后发送reload消息给table以重新填充表格单元内容, 如图

iPhone应用:Sqlite和UITableView实现大数据浏览案例

如果消息记录超过一条, 记得在

- (NSInteger)tableView:(UITableView *)tableView numberOfRowsInSection:(NSInteger)section 

中返回消息记录 + 1, 因为最后一个cell需要实现 Get More …功能。

就像上一步说的, 点击最后一个cell也就是Get More…时,在此从服务器获取 新的timelines, 将其解析再写入数据表中, 每次刷新时将数据表清空,否则显示的消息会越来越多:), Get More 工作状态大概时这样的,如图:

iPhone应用:Sqlite和UITableView实现大数据浏览案例

如此, 程序实用的内存非常小, 每一条消息内容都是在需要的时候从数据库文件中读取, 减小了内存使用量就增加了程序的稳定性, 这对于成功的软件来说是非常必要的。

相关推荐