- r - 以节省内存的方式增长 data.frame
- ruby-on-rails - ruby/ruby on rails 内存泄漏检测
- android - 无法解析导入android.support.v7.app
- UNIX 域套接字与共享内存(映射文件)
我的应用程序有一个由 Sqlite DB 填充的表,其中包含大量数据所以导致table view延迟加载
这是代码
- (void) searchData {
//i=0;
[newSearchBar setShowsCancelButton:YES animated:YES];
NSLog(@"search data started ");
NSLog(@" checking value %@",newSearchBar.text);
NSString *databaseName = @"imeating.sql";
NSArray *documentPaths = NSSearchPathForDirectoriesInDomains(NSDocumentDirectory, NSUserDomainMask,YES);
NSString *documentsDir=[documentPaths objectAtIndex:0];
NSString *databasePath=[documentsDir stringByAppendingPathComponent:databaseName];
sqlite3 *database;
if (sqlite3_open([databasePath UTF8String], &database) == SQLITE_OK)
{
NSLog(@"with in if sqlite3 open");
// Setup the SQL Statement and compile it for faster access
sqlite3_stmt *compiledStatement ;
const char *sqlStatement ;
/* if ([searchFlag isEqualToString:@"DEF"])
{
sqlStatement = "select subitem_name, subitem_detail_id from subitem_detail limit 200" ;
}
else
{*/
sqlStatement = "select category_id, upper(subitem_name), subitem_detail_id, protein, carbohydrates, fat, calorie from subitem_detail where subitem_name LIKE ? order by subitem_name limit ?,?" ;
NSLog(@"inside search b4 wildsearch %@",searchString);
wildSearch = [NSString stringWithFormat:@"%@%@",searchString, @"%"];
NSLog(@"wildsearch %@",wildSearch);
[newSearchBar setShowsCancelButton:YES animated:YES];
//NSLog(@"inside search : %@", wildSearch);
//}
if (sqlite3_prepare_v2(database, sqlStatement, -1, &compiledStatement, NULL) == SQLITE_OK)
{
NSLog(@"with in if sqlite3 prepare v2");
// if (![searchFlag isEqualToString:@"DEF"])
// {
sqlite3_bind_text(compiledStatement, 1, [wildSearch UTF8String], -1, SQLITE_TRANSIENT);
sqlite3_bind_int(compiledStatement, 2, llimit);
sqlite3_bind_int(compiledStatement, 3, ulimit);
// }
// Loop through the results and add it to array
if (llimit <200){
NSLog(@"with in if limit < 200");
itemArray = [[NSMutableArray alloc] init] ;
}
while (sqlite3_step(compiledStatement) == SQLITE_ROW) {
//NSLog(@" while sqlite3 step");
NSAutoreleasePool *pool = [[NSAutoreleasePool alloc] init] ;
//[itemDic release];
//itemDic = nil ;
itemDic = [[[NSMutableDictionary alloc] init] autorelease];
NSString *categoryId = [NSString stringWithUTF8String:(char *)sqlite3_column_text(compiledStatement, 0)];
NSString *itemName = [NSString stringWithUTF8String:(char *)sqlite3_column_text(compiledStatement, 1)];
NSString *itemId = [NSString stringWithUTF8String:(char *)sqlite3_column_text(compiledStatement, 2)];
NSString *protein = [NSString stringWithUTF8String:(char *)sqlite3_column_text(compiledStatement, 3)];
NSString *carbo = [NSString stringWithUTF8String:(char *)sqlite3_column_text(compiledStatement, 4)];
NSString *fat = [NSString stringWithUTF8String:(char *)sqlite3_column_text(compiledStatement, 5)];
NSString *calorie = [NSString stringWithUTF8String:(char *)sqlite3_column_text(compiledStatement, 6)];
/* NSLog(@"itemname : %@", itemName);
NSLog(@"itemid : %@", itemId);
NSLog(@"\n");*/
[itemDic setObject:categoryId forKey:@"categoryId"];
[itemDic setObject:itemId forKey:@"itemId"];
[itemDic setObject:itemName forKey:@"itemName"];
[itemDic setObject:protein forKey:@"protein"];
[itemDic setObject:carbo forKey:@"carbohydrate"];
[itemDic setObject:fat forKey:@"fat"];
[itemDic setObject:calorie forKey:@"calorie"];
[itemArray addObject:itemDic];
if (ulimit%200 == 0)
{
//activity = [[UIActivityIndicatorView alloc] initWithActivityIndicatorStyle:UIActionSheetStyleDefault];
//[activity startAnimating];
[newTableView reloadData];
//[newSearchBar setShowsCancelButton:YES animated:YES];
//NSLog(@"list all views after 1st reload: %@", [self.navigationController.viewControllers description]);
//[newTableView addSubview:activity];
//[activity stopAnimating];
//[activity release];
//NSLog(@" with in if");
}
[pool drain];
} /*else
{
UIAlertView *alert = [[UIAlertView alloc ] initWithTitle:@"Error" message:@"sqlite rows not returned" delegate:self cancelButtonTitle:@"OK" otherButtonTitles: nil] ;
[alert show];
}*/
}
} else
{
UIAlertView *alert = [[UIAlertView alloc ] initWithTitle:@"Error" message:@"DataBase Path doesn't exists" delegate:self cancelButtonTitle:@"OK" otherButtonTitles: nil] ;
[alert show];
}
//NSLog(@"itemArray desc : %@",[itemArray description]);
}
- (NSInteger)numberOfSectionsInTableView:(UITableView *)tableView
{
//NSLog(@"Inside number of sections in tableview");
return 1;
}
- (NSInteger)tableView:(UITableView *)tableView numberOfRowsInSection:(NSInteger)section
{
return [itemArray count] ;
}
// Customize the appearance of table view cells.
- (UITableViewCell *)tableView:(UITableView *)tableView cellForRowAtIndexPath:(NSIndexPath *)indexPath
{
static NSString *CellIdentifier = @"Cell";
UITableViewCell *cell = [tableView dequeueReusableCellWithIdentifier:CellIdentifier];
if (cell == nil) {
cell = [[[UITableViewCell alloc] initWithStyle:UITableViewCellStyleSubtitle reuseIdentifier:CellIdentifier] autorelease];
}
//NSLog(@"indexpath row val : %d", indexPath.row);
tableIndex = indexPath ;
//NSLog(@"print indexpath row : %d", indexPath.row);
//NSLog(@"print limit : %d", limit);
if (indexPath.row > limit)
{
llimit = llimit+200 ;
ulimit = ulimit+200 ;
NSAutoreleasePool *pool = [[NSAutoreleasePool alloc] init];
//[opq cancelAllOperations];
NSLog(@"before ns operation");
opq = [NSOperationQueue new];
//opq = [[NSOperationQueue alloc] init];
//[opq setMaxConcurrentOperationCount:2];
// [self performSelectorOnMainThread:@selector(searchData) withObject:nil waitUntilDone:YES];
NSInvocationOperation *op = [[[NSInvocationOperation alloc] initWithTarget:self selector:@selector(searchData) object:nil] autorelease];
[opq addOperation:op];
NSLog(@"after ns operation");
//[op release];
//[opq release];
[pool drain];
i++;
limit = limit + 120 ;
NSLog(@"i=%d",i);
//[cell setText:[[itemArray objectAtIndex:indexPath.row] valueForKey:@"itemName"]];
}
// Configure the cell.
//[cell setText:[[itemArray objectAtIndex:indexPath.row] valueForKey:@"itemName"]];
cell.textLabel.text = [[itemArray objectAtIndex:indexPath.row] valueForKey:@"itemName"] ;
NSString *pval, *cval, *fval, *cal ;
if ([[[itemArray objectAtIndex:indexPath.row] valueForKey:@"protein"] length] <= 5)
pval = [[itemArray objectAtIndex:indexPath.row] valueForKey:@"protein"];
else
pval = [[[itemArray objectAtIndex:indexPath.row] valueForKey:@"protein"] substringWithRange:NSMakeRange(0, 5)];
if ([[[itemArray objectAtIndex:indexPath.row] valueForKey:@"carbohydrate"] length] <= 5)
cval = [[itemArray objectAtIndex:indexPath.row] valueForKey:@"carbohydrate"];
else
cval = [[[itemArray objectAtIndex:indexPath.row] valueForKey:@"carbohydrate"] substringWithRange:NSMakeRange(0, 5)];
if ([[[itemArray objectAtIndex:indexPath.row] valueForKey:@"fat"] length] <= 5)
fval = [[itemArray objectAtIndex:indexPath.row] valueForKey:@"fat"];
else
fval = [[[itemArray objectAtIndex:indexPath.row] valueForKey:@"fat"] substringWithRange:NSMakeRange(0, 5)];
if ([[[itemArray objectAtIndex:indexPath.row] valueForKey:@"calorie"] length] <= 5)
cal = [[itemArray objectAtIndex:indexPath.row] valueForKey:@"calorie"];
else
cal = [[[itemArray objectAtIndex:indexPath.row] valueForKey:@"calorie"] substringWithRange:NSMakeRange(0, 5)];
cell.detailTextLabel.text =
[NSString stringWithFormat:@"Prot: %@ Carb: %@ Fat: %@ Cal: %@", pval, cval, fval, cal] ;
return cell;
}
我的 TableView 需要行中的“加载更多”按钮才能在特定的限制期间从 sqlite 数据库加载记录
最佳答案
将 a + 1 添加到部分中的行数:
- (NSInteger)tableView:(UITableView *)tableView numberOfRowsInSection:(NSInteger)section
{
return [itemArray count] + 1;
}
然后在 cellforrowatindexpath 中,查看 indexPath.row 是否大于 [itemArray count]。如果是,则将文本“加载更多...”作为该单元格的标题。
在 didSelectRowAtIndexPath 中,查看 indexPath.row 是否等于 [itemArray count]。如果是这种情况,则向 itemArray 添加 x 个结果,然后调用 [tableView reloadData]。
对于某些 UI 改进,您可以在 TableView 顶部添加一个 UIActivityIndicator,以显示后台正在进行某些处理。
关于iphone - 如何将 "load more"选项添加到 TableView ,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/5898399/
我创建了一个用户可以添加测试的字段。这一切运行顺利我只希望当用户点击(添加另一个测试)然后上一个(添加另一个测试)删除并且这个显示在新字段中。 所有运行良好的唯一问题是点击(添加另一个字段)之前添加另
String[] option = {"Adlawan", "Angeles", "Arreza", "Benenoso", "Bermas", "Brebant
关闭。这个问题不符合Stack Overflow guidelines .它目前不接受答案。 这个问题似乎不是关于 a specific programming problem, a softwar
我正在努力将 jQuery 滚动功能添加到 nav-tab (Bootstrap 3)。我希望用户能够选择他们想要的选项卡,并在选项卡内容中有一个可以平滑滚动到 anchor 的链接。这是我的代码,可
我正在尝试在用户登录后再添加 2 个 ui 选项卡。首先,我尝试做一个之后。 $('#slideshow').tabs('remove', '4'); $("#slideshow ul li:last
我有一个包含选择元素的表单,我想通过选择添加和删除其中一些元素。这是html代码(这里也有jsfiddle http://jsfiddle.net/txhajy2w/):
正在写这个: view.backgroundColor = UIColor.white.withAlphaComponent(0.9) 等同于: view.backgroundColor = UICo
好的,如果其中有任何信息,我想将这些列添加到一起。所以说我有 账户 1 2 3 . 有 4 个帐户空间,但只有 3 个帐户。我如何创建 java 脚本来添加它。 最佳答案 Live Example H
我想知道是否有一种有效的预制算法来确定一组数字的和/差是否可以等于不同的数字。示例: 5、8、10、2,使用 + 或 - 等于 9。5 - 8 = -3 + 10 = 7 + 2 = 9 如果有一个预
我似乎有一个卡住的 git repo。它卡在所有基本的添加、提交命令上,git push 返回所有内容为最新的。 从其他帖子我已经完成了 git gc 和 git fsck/ 我认为基本的调试步骤是
我的 Oracle SQL 查询如下- Q1- select hca.account_number, hca.attribute3, SUM(rcl.extended_amou
我正在阅读 http://developer.apple.com/iphone/library/documentation/iPhone/Conceptual/iPhoneOSProgrammingG
我正在尝试添加一个“加载更多”按钮并限制下面的结果,这样投资组合页面中就不会同时加载 1000 个内容,如下所示:http://typesetdesign.com/portfolio/ 我对 PHP
我遇到这个问题,我添加了 8 个文本框,它工作正常,但是当我添加更多文本框(如 16 个文本框)时,它不会添加最后一个文本框。有人遇到过这个问题吗?提前致谢。 Live Link: JAVASCRIP
add/remove clone first row default not delete 添加/删除克隆第一行默认不删除&并获取正确的SrNo(例如:添加3行并在看到问题后删除SrNo.2)
我编码this ,但删除按钮不起作用。我在控制台中没有任何错误.. var counter = 0; var dataList = document.getElementById('materi
我有一个类似数组的对象: [1:数组[10]、2:数组[2]、3:数组[2]、4:数组[2]、5:数组[3]、6:数组[1]] 我正在尝试删除前两个元素,执行一些操作,然后将它们再次插入到同一位置。
使用的 Delphi 版本:2007 你好, 我有一个 Tecord 数组 TInfo = Record Name : String; Price : Integer; end; var Info
我使用了基本的 gridster 代码,然后我声明了通过按钮添加和删除小部件的函数它工作正常但是当我将调整大小功能添加到上面的代码中时,它都不起作用(我的意思是调整大小,添加和删除小部件) 我的js代
title 323 323 323 title 323 323 323 title 323 323 323 JS $(document).keydown(function(e){
我是一名优秀的程序员,十分优秀!