私のiPhoneアプリケーションからサーバーに接続するためにAsyncSocketを使用しています。さて、これをNSNotification AsyncSocketと組み合わせて使用したときの奇妙さ
- (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");
}
:
- (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上:サーバからデータを受け取ったデリゲートでは、私はのtableViewのreloadDataをトリガするためのtableViewのデリゲートを言うだろう通知を投稿しますまったく動作しません。通知はポーズされていますが、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のデリゲートメソッドと何か関係がありますか?
ありがとうございます。
私は、initWithNibName:bundle:メソッドにブレークポイントを設定しましたが、実際に通知登録が実行されました。 また、viewControllerはapplicationDidFinishLaunchingメソッドで通知された通知を受け取りました。 本当に奇妙です。つまり、AsyncSocketはnsnotificationの動作に影響しないはずです。 – Ben
AsyncSocketは通知に影響しません。 onSocketについて:didReadData :?メソッドが呼ばれていると確信していますか?最初の読み取りを開始することはできません。 –