0

我有一种情况,我需要暂时使用一些字符串,但我已经阅读了很多相互矛盾的东西,以至于我对最好的处理方式有点困惑。

我需要在 if 结构中分配一些字符串,但在 if 结构之外使用它们,因此需要在 if 之外创建它们,我在想类似的事情:

NSString *arbString = [[NSString alloc] init];

if(whatever)
{
    arbString = @"Whatever"
}
else
{
    arbString = @"SomethingElse"
}

myLabel.text = arbString;
[arbString release];

我见过人们刚刚使用的例子:

NSString *arbString;

创建字符串变量

谷歌的 Objective C 指南说它最好在创建时自动发布:

“创建新的临时对象时,在创建它们的同一行自动释放它们,而不是稍后在同一方法中单独释放”:

// AVOID (unless you have a compelling performance reason)
MyController* controller = [[MyController alloc] init];
// ... code here that might return ...
[controller release];

// BETTER
MyController* controller = [[[MyController alloc] init] autorelease];

所以我不知道,哪个是最佳实践?

4

1 回答 1

1

在您发布的示例中,您实际上丢失了对您在分配时创建的 NSString 的引用arbString = @"Whatever"。然后释放字符串常量(顺便说一句,这是不可释放的)。

因此存在内存泄漏,因为您从未释放您创建的 NSString。

请记住,所有这些类型都是指针,因此=只需重新分配它们。

至于问题,在此示例中,您不需要[[NSString alloc] init]. 无论如何,您都不需要将字符串复制到局部变量中,只需设置myLabel.text为字符串常量即可@"Whatever"

(编辑:这并不是说你不能使用你的指针arbStringarbString = @"Whatever"; myLabel.text = arbString很好。但这只是指针赋值,而不是复制)

If you needed to manipulate the string before you returned it, you would create an NSMutableString, and either release or auto-release it. Personally, create autoreleased objects using class methods, so in this example, I'd use [NSString string], or [NSString stringWithString:], which return autoreleased objects.

于 2010-07-05T10:37:17.390 回答