Thursday, June 30, 2011

Difference between NSString and NSMuttableString



//  Setup  two  variables  to  point  to  the  same  string
NSString * str1 = @"Hello World";

NSString * str2 = str1;


//  "Replace"  the  second  string
str2 = @"Hello ikilimnik";


//  And  list  their  current  values
NSLog(@"str1 = %@, str2 = %@", str1, str2);


Mutable strings


//  Setup  two  variables  to  point  to  the  same  string
NSMutableString * str1 = [NSMutableString stringWithString:@"Hello World"];

NSMutableString * str2 = str1;


//  "Replace"  the  second  string
[str2 setString:@"Hello ikilimnik"];


//  And  list  their  current  values
NSLog(@"str1 = %@, str2 = %@", str1, str2);


Notice when you use the immutable NSString class that the only way to "replace" a string is to create a new string and update your variable "str2" to po
int to it. 
This however doesn't affect what "str1" is pointing to, so it will still reference the original string.


In the NSMutableString example, we don't create a second string, but instead alter (mutate) the contents of 

the existing "Hello World" string. Since both variables continue to po
int to the same string object, they will both report the new value in the call to NSLog.

It's important to differentiate between a pointer variable and the actual object it points to. 

A NSString object is immutable, but that doesn't stop you from changing the value of a variable which points to a string.


The data type "NSString *" is a pointer to a NSString object, not the object itself. 

If you set a break po
int at either of the NSLog statements within the XCode debugger, you may like to check the raw value of each variable to clarify this.


Reference:


http:
//www.cocoadev.com/index.pl?NSString

http:
//stackoverflow.com/questions/1805442/nsstring-immutable-allows-to-change-its-values

No comments:

Create a list in SwiftUI with sticky section headers

 Sample Code import SwiftUI struct ContentView : View {     @State var isCustomViewControllerDisplayed = false     @State private va...