sText is an instance variable of type NSString. No properties are involved.
The loop below is supposed to get the first character of sText and store that char in sCurrentCharacter. Then the rest of sText should be reassigned to sText. This goes on until the string has been eaten up.
(I left out all the code which actually does something sensible to the variables).
while ([sText length] > 0)
{
// Get the current first ASCII character.
NSString *sCurrentCharacter = [sMorseText substringToIndex:1];
// Keep everything but the first character.
sText = [sText substringFromIndex:1];
}
Questions: do I have to release sText before reassigning the result of “substringFromIndex”? If yes: why? If not: why not? 🙂
René
That depends on how you created the initial
sText. IfsTextis an autoreleased object or you have not explicitly retained it, then you are fine. If you created sText usinginit,copyorretained it, then you should autorelease it before the while loop.so this is fine:
This will leak the original value of
sText: