Warum werden schwache NSString-Eigenschaften in iOS nicht veröffentlicht?

Ich habe den folgenden Beispielcode geschrieben, um zu sehen, wie ARC funktioniert

@property (nonatomic, weak) NSString *myString;
@property (nonatomic, weak) NSObject *myObj;
@end

@implementation ViewController
@synthesize myString = _myString;
@synthesize myObj = _myObj;
- (void) viewDidAppear:(BOOL)animated
{
    NSLog(@"Appearing Obj: !%@!",self.myObj);
    NSLog(@"Appearing String: !%@!",self.myString);
}

- (void)viewDidLoad
{
    self.myObj = [[NSObject alloc] init];
    self.myString = [[NSString alloc] init];
    NSLog(@"Loading Obj %@",self.myObj);
    NSLog(@"Loading String: !%@!",self.myString);
}

Allerdings habe ich überraschenderweise folgende Ergebnisse erhalten:

2012-06-19 15:08:22.516 TESTER[4041:f803] Loading Obj (null)
2012-06-19 15:08:22.517 TESTER[4041:f803] Loading String: !!
2012-06-19 15:08:22.533 TESTER[4041:f803] Appearing Obj: !(null)!
2012-06-19 15:08:22.535 TESTER[4041:f803] Appearing String: !!

Wie Sie sehen, wurde Obj richtig freigegeben, aber mein String (der auch eine schwache Eigenschaft ist) gibt nicht null aus ... Warum nicht?

Antworten auf die Frage(2)

Ihre Antwort auf die Frage