Я начал играть в Xcode 4.2 с новым NSLinguisticTagger от iOS 5.0. Моя цель с этой функцией - взять запись в адресной книге, а затем выплюнуть составное имя как NSString, похожее на то, что делает ABRecordCopyCompositeName, но с учетом порядка именования для восточноазиатских языков и венгерского (последнее первое, а не первое). Вот функция:NSLinguisticTagger Memory Leak
NSString *text = [self getLocalizedFullNameOfRecord:[contacts objectAtIndex:indexPath.section];
- (NSString *) getLocalizedFullNameOfRecord:(ABRecordRef) person
{
NSString *firstName = ABRecordCopyValue(person, kABPersonFirstNameProperty);
NSString *middleName = ABRecordCopyValue(person, kABPersonMiddleNameProperty);
NSString *lastName = ABRecordCopyValue(person, kABPersonLastNameProperty);
NSString *prefix = ABRecordCopyValue(person, kABPersonPrefixProperty);
NSString *suffix = ABRecordCopyValue(person, kABPersonSuffixProperty);
NSString *fullName = @"";
__block BOOL Asian;
// Apologies to all Hungarians who aren't actually Asian
__block NSArray *asianLanguages = [NSArray arrayWithObjects:@"zh-Hant", @"zh-Hans", @"ja", @"ko", @"hu", @"vi", nil];
[firstName enumerateLinguisticTagsInRange:NSMakeRange(0, firstName.length) scheme: NSLinguisticTagSchemeLanguage options: NSLinguisticTaggerOmitWhitespace orthography: nil usingBlock:^(NSString *tag, NSRange tokenRange, NSRange sentenceRange, BOOL *stop){
if ([asianLanguages containsObject:tag])
Asian = YES;
else
Asian = NO;
}];
if(prefix)
fullName = [fullName stringByAppendingFormat:@"%@ ", prefix];
if(Asian && lastName)
fullName = [fullName stringByAppendingFormat:@"%@ ", lastName];
else if(firstName)
fullName = [fullName stringByAppendingFormat:@"%@ ", firstName];
if(middleName)
fullName = [fullName stringByAppendingFormat:@"%@ ", middleName];
if(Asian && firstName)
fullName = [fullName stringByAppendingFormat:@"%@ ", firstName];
else if(lastName)
fullName = [fullName stringByAppendingFormat:@"%@ ", lastName];
if(suffix)
fullName = [fullName stringByAppendingFormat:@"%@", suffix];
[firstName release];
[middleName release];
[lastName release];
[prefix release];
[suffix release];
return fullName;
}
Instruments говорит мне, что я утечка около 16 до 32 байт с каждой итерации этой функции на enumerateLinguisticTagger (а не блокирует часть, видимо). Поскольку онлайн-ресурсы для NSLinguisticTagger ограничены ссылкой на класс и одним учебным пособием, я понятия не имею, где и как начать поиск утечки.
Помогите, пожалуйста?
+1 для полезной части кода. Я смотрел на это (http://www.w3.org/International/questions/qa-personal-names) и задавался вопросом, как я собираюсь это сделать и, эй-престо, Serendipity на помощь :-) –