fmdb iphone 3g大型阵列

fmdb iphone 3g大型阵列,iphone,memory-management,nsmutablearray,fmdb,Iphone,Memory Management,Nsmutablearray,Fmdb,我在固件为4.2.1(8C148)的iphone 3g的fmdb上遇到了一些问题。 我有一个大型NSMutableArray,其中包含sql命令(从数据库下载)。我通过NSAutoreleasePool(为iphone 3g释放一些内存的一部分)填充NSMutableArray,得到了一个40+mb的阵列 然后,我使用以下命令: [db beginTransaction]; for (NSString* sql in updateSQL) { if (sql!=@"") { BO

我在固件为4.2.1(8C148)的iphone 3g的fmdb上遇到了一些问题。 我有一个大型NSMutableArray,其中包含sql命令(从数据库下载)。我通过NSAutoreleasePool(为iphone 3g释放一些内存的一部分)填充NSMutableArray,得到了一个40+mb的阵列

然后,我使用以下命令:

 [db beginTransaction];
 for (NSString* sql in updateSQL)
 {
  if (sql!=@"") {
   BOOL fmtest = [db executeUpdate:sql];
   if (!fmtest) {
    NSLog(@"Sql FAIL: %@",sql);
   }
   if ([db hadError]) {
    NSLog(@"Err %d: %@", [db lastErrorCode], [db lastErrorMessage]);
   }
 }
 // fetches--; // Counter of total updates;
}
[db commit];
在更新过程中,我得到了40/50MB的内存分配。iphone3g无法处理这个问题,它失败得很惨,出现了1级警告,最后退出

我在iPhone3GS上试用过,效果很好


有人知道怎么跳过这个吗?我不能使用核心数据(即使这是一个很好的解决方案),因为我已经有一个与应用程序捆绑在一起的大型数据库。

使用

[db close];
确保释放不再使用的内存


大多数开发人员试图尽可能长时间地保持数据库连接的打开状态。然而,在iPhone上,由于内存限制最为严格,IO速度最快,每次通话时重复打开/关闭DB的速度通常更快。

是的,这就成功了!我看到我的内存分配从15->48+兆的峰值变为15-20兆的稳定。明天我将尝试测试3g(我的主要测试是3gs)。4和Ipad工作起来很有魅力。