0

AsyncSocket を使用して、iPhone アプリからサーバーに接続しています。サーバーからデータを受信したデリゲートで、tableView のデリゲートに tableView で reloadData をトリガーするように指示する通知をポストします。

- (void)onSocket:(AsyncSocket *)sock didReadData:(NSData*)data withTag:(long)tag {
    [[NSNotificationCenter defaultCenter] postNotificationName:@"PEERSTATUSCHANGED" object:self];
    [sock readDataToData:[AsyncSocket CRLFData] withTimeout:-1 tag:0];
}

そしてviewControllerで:

- (id)initWithNibName:(NSString *)nibNameOrNil bundle:(NSBundle *)nibBundleOrNil {
    if (self = [super initWithNibName:nibNameOrNil bundle:nibBundleOrNil]) {
        [[NSNotificationCenter defaultCenter] addObserver:self selector:@selector(peerStatusDidChange:) name:@"PEERSTATUSCHANGED" object:nil];
    }
    return self;
}


- (void)peerStatusDidChange:(NSNotification *)notification {
    NSLog(@"NOTIFICATION RECEIVED");
}

さて、これはまったく機能しません。通知は発生しますが、ViewController によって認識されません。ただし、applicationDidFinishLaunching で同じことを行うと、次のようになります。

- (void)applicationDidFinishLaunching:(UIApplication *)application {    

protocol = [[XBBProtocol alloc] init];

SourceListViewController *sourceListVC = [[[SourceListViewController alloc] initWithNibName:@"SourceListViewController" bundle:nil] autorelease];
UINavigationController *navigationController = [[[UINavigationController alloc] initWithRootViewController:sourceListVC] autorelease];

[[NSNotificationCenter defaultCenter] postNotificationName:@"PEERSTATUSCHANGED" object:self];
[protocol connectToServer];

// Override point for customization after application launch
[window addSubview:[navigationController view]];
[window makeKeyAndVisible];
}

viewControllerで受信した通知を受け取りました。

誰でも理由を知っていますか?別のスレッドにある AsyncSocket のデリゲート メソッドと関係がありますか?

前もって感謝します。

4

2 に答える 2

1

通知を送信するメソッドを別のメソッドに入れて、「performSelectorOnMainThread」で呼び出してみてください。ネットワークコードがバックグラウンドスレッドで呼び出されている可能性が非常に高いため、通知が発生すると、同じスレッドのテーブルビューに通知されます...

メイン スレッド以外で UI 呼び出しを行うことはできません。

于 2009-06-28T20:44:28.937 に答える
1

1 つの可能性は、initWithNibName:bundle:メソッドが実際に呼び出されていないことです。View Controller を (コードではなく) NIB でインスタンス化すると、initWithCoder:代わりに呼び出されます。

確認する簡単な方法は、 にブレークポイントを設定することinitWithNibName:bundle:です。

于 2009-06-28T15:27:24.087 に答える