0

この問題は非常に単純です。私はそれを処理する方法を理解するのに苦労しています。

私は次のようにデータを読みます:

[asyncSocket readDataWithTimeout:-1 tag:2];

NSString *failure = [serverJSONResponseParsed objectForKey:@"failure"];
NSLog(@"Contents of string failure: %@", failure);

if ([failure isEqualToString:@"none"]) {
    NSLog(@"Success Sending String");
    return TRUE;
}
else {
    NSLog(@"Failure: %@",failure);
    return FALSE;
}

ここで、予想どおり、デリゲート メソッドが呼び出され、JSON データを適切に読み取ります。

-(void)socket:(GCDAsyncSocket *)sock didReadData:(NSData *)data withTag:(long)tag {
    NSError *error;
    NSLog(@"didReadData: %@", [[NSString alloc] initWithData:data encoding:NSUTF8StringEncoding]);
    serverJSONResponseParsed = [NSJSONSerialization JSONObjectWithData:data options:kNilOptions error:&error];
    NSLog(@"didReadData test after dict: %@", [serverJSONResponseParsed objectForKey:@"failure"]);
}

問題は、GCDAsyncSocket が非同期であるため、このコード ブロックです。

NSString *failure = [serverJSONResponseParsed objectForKey:@"failure"];
NSLog(@"Contents of string failure: %@", failure);

if ([failure isEqualToString:@"none"]) {
    NSLog(@"Success Sending String");
    return TRUE;
}
else {
    NSLog(@"Failure: %@",failure);
    return FALSE;
}

[asyncSocket readDataWithTimeout:-1 tag:2];

データが読み込まれる前に呼び出されます。データが読み込まれたことを確認してから分析するにはどうすればよいでしょうか。

4

1 に答える 1

1

そのコードのブロックは、次のように、didReadDataコールバックメソッドに含まれている必要があります。

    -(void)socket:(GCDAsyncSocket *)sock didReadData:(NSData *)data withTag:(long)tag {
        NSError *error;
        NSLog(@"didReadData: %@", [[NSString alloc] initWithData:data encoding:NSUTF8StringEncoding]);
        serverJSONResponseParsed = [NSJSONSerialization JSONObjectWithData:data options:kNilOptions error:&error];
        NSLog(@"didReadData test after dict: %@", [serverJSONResponseParsed objectForKey:@"failure"]);

    NSString *failure = [serverJSONResponseParsed objectForKey:@"failure"];
    NSLog(@"Contents of string failure: %@", failure);

    if ([failure isEqualToString:@"none"]) {
        NSLog(@"Success Sending String");
        return TRUE;
    }
    else {
        NSLog(@"Failure: %@",failure);
        return FALSE;
    }
}
于 2012-08-19T01:17:28.973 に答える