0

我正在编写一个 iPhone 应用程序,它应该解析来自网络的平面文件,从平面文件创建托管对象,然后应该在 UITableView 中显示它们。保存和显示都没有问题,但我就是无法掌握一个好的解析器。

这就是我要解析的文件:平面文件

据我所知,我不能将 NSXMLParser 用于此任务(因为显然没有标签)。

所以我一开始尝试编写一个 NSScanner 来获得有趣的属性 --> 没有成功

现在我正在使用这种方法:

- (void) parseMemberDataWithURL: (NSString *)urlString
{
    self.memberTempCounter = 1;

    //Get data from web
    self.downloadedText = [NSString stringWithContentsOfURL: [NSURL URLWithString:    urlString] encoding:NSUTF8StringEncoding error:nil ];

    memberArray = [downloadedText componentsSeparatedByString:@";"];

    while (self.memberTempCounter<[memberArray count])
    {
        [[ExhibitorController sharedController] createExhibitorWithName:[memberArray objectAtIndex:self.memberTempCounter]
                                                                  street:[memberArray objectAtIndex:self.memberTempCounter+2]
                                                                    zip:[memberArray objectAtIndex:self.memberTempCounter+3]
                                                                   city:[memberArray objectAtIndex:self.memberTempCounter+4]
                                                                  email:[memberArray objectAtIndex:self.memberTempCounter+7]
                                                                  phone:[memberArray objectAtIndex:self.memberTempCounter+5]
                                                                website:[memberArray objectAtIndex:self.memberTempCounter+8]
                                                        produktbereiche:[[memberArray objectAtIndex:self.memberTempCounter+9] componentsSeparatedByString:@","]];
        self.memberTempCounter= self.memberTempCounter+13;
    } 
}

我正在使用 memberTempCounter 来识别属性。

问题是:

  • 这只适用于 4 次中的 3 次。应用程序崩溃 4 次中的 1 次,我不知道为什么......
  • 该方法具有类似于 1962 年大众甲壳虫的性能。在我的 iPhone 3G 上解析整个数据块最多需要 3 分钟

有什么想法或更简单的方法吗?

我真的很感激。提前致谢: -)

4

3 回答 3

1

您不妨在后台进行所有解析,然后在信息被解析时显示。

至于内存问题,请尝试执行临时自动释放池,并通过循环每 50 次左右迭代释放一次。

int count = 0;
NSAutoreleasePool * loopPool = [[NSAutoreleasePool alloc] init];
while(someInsanelyLargeCondition){

    // Do your stuff here
    // .............

    count++;
    if (count > 50) {
        count = 0;
        [loopPool release];
        loopPool = [[NSAutoreleasePool alloc] init];
    }
}
于 2010-09-03T19:46:22.483 回答
0

我终于能够解决我的性能问题。

我在另一个类中有一个方法,它为不同的参展商广告标签。因此它首先检查标签是否已经存储在数据库中或者创建它。随着我的数据库中标签集的增加,搜索过程花费的时间越来越长,这导致解析时间变长。

有这个问题的其他人:在“高效实现查找或创建”部分中查看苹果的性能核心数据编程指南:

http://developer.apple.com/mac/library/documentation/Cocoa/Conceptual/CoreData/Articles/cdImporting.html

于 2010-09-07T08:21:08.750 回答
0

Recursive-descent (LL1) 解析器非常简单,占用内存少,而且就速度而言,它们的运行速度几乎与通过字符运行指针一样快。构建你的数据结构可能是主要的耗时。

于 2010-09-03T16:37:18.187 回答