【发布时间】:2011-03-09 09:24:16
【问题描述】:
我正在使用 DBManager 类从 SQlite 数据库中重新运行数据。该类包含通过从数据库中获取 MutableArray 来返回 MutableArray 的方法。像下面这样..
+ (NSMutableArray *) getSaleForYear : (NSString *) year {
if ([DBManager openDBConnection]) {
NSMutableArray * sales = [[NSMutableArray alloc] initWithCapacity:1];
const char *q = "SELECT sales, quarter FROM sale where year like ? order by quarter";
sqlite3_stmt *selectstmt;
if (sqlite3_prepare_v2(database, q, -1, &selectstmt, NULL) == SQLITE_OK) {
if(sqlite3_bind_text(selectstmt, 1, [year UTF8String] , -1, SQLITE_TRANSIENT) != SQLITE_OK){
NSLog(@"bind error : %@", [NSString stringWithUTF8String: sqlite3_errmsg(database)]);
return nil;
}
while(sqlite3_step(selectstmt) == SQLITE_ROW) {
float sale = sqlite3_column_double(selectstmt, 0);
//NSString * quarter = [NSString stringWithUTF8String:(char *)sqlite3_column_text(selectstmt, 1)];
NSString * quarter = [[NSString alloc] initWithUTF8String:(char *)sqlite3_column_text(selectstmt, 1)];
ChartData * b1 = [[ChartData alloc] initwithdata:quarter y:sale];
[sales addObject:b1];
[b1 release];
[quarter release];
}
}
sqlite3_finalize(selectstmt);
[DBManager closeDBConnection];
return [sales autorelease];
}else {
return nil;
}
}
我正在调用类似的方法。
- (IBAction) getData {
NSLog(@"getdata");
if (arr != nil) {
for (ChartData * cd in arr) {
[cd release];
}
arr = nil;
[arr release];
}
arr = [[DBManager getSaleForYear:@"2010-11"] copy];
NSLog(@"count %d ", [arr count]);
}
这种方法会为函数的迭代调用造成内存泄漏。 请提出泄漏原因和解决方案。
【问题讨论】:
标签: iphone ipad memory-management memory-leaks