1

有了 NSOutputStream,我第一次就可以完美地写出来。

下面是发送数据的方法:

- (NSInteger)sendVsCommand:(VsCommand *)command
{
    NSData *commandArray = [NSData dataWithData:[command getCommandArray]];
    NSLog(@"Space availiable: %d", [writeStream hasSpaceAvailable]);
    NSInteger result = [writeStream write:[commandArray bytes] 
                                maxLength:[commandArray length]];
    NSLog(@"Writing result: %d", result);
    return result;
}

这是事件的处理:

case NSStreamEventHasSpaceAvailable:
            NSLog(@"%@ can accept bytes", aStream);
            if (aStream == writeStream) {
                NSLog(@"Can send data: %d", [writeStream hasSpaceAvailable]);
            }
            break;

无论如何,只是重要的“案例”。

以下是控制台中的结果:

2013-08-16 18:07:12.769 hMonitor[5765:307] <__NSCFInputStream: 0x148650> is open
2013-08-16 18:07:12.776 hMonitor[5765:307] <__NSCFOutputStream: 0x148330> is open
2013-08-16 18:07:12.777 hMonitor[5765:307] <__NSCFOutputStream: 0x148330> can accept bytes
2013-08-16 18:07:12.779 hMonitor[5765:307] Can send data: 1
2013-08-16 18:07:13.107 hMonitor[5765:307] <__NSCFInputStream: 0x148650> has bytes
2013-08-16 18:07:13.112 hMonitor[5765:307] Space availiable: 1
2013-08-16 18:07:13.116 hMonitor[5765:307] Writing result: 41
2013-08-16 18:07:13.118 hMonitor[5765:307] <__NSCFOutputStream: 0x148330> can accept bytes
2013-08-16 18:07:13.119 hMonitor[5765:307] Can send data: 1
2013-08-16 18:07:13.687 hMonitor[5765:307] <__NSCFInputStream: 0x148650> has bytes
2013-08-16 18:07:15.343 hMonitor[5765:307] Space availiable: 0
2013-08-16 18:07:15.345 hMonitor[5765:307] Writing result: 0
  1. 如您所见,当流打开时,我可以写得很好(可以发送数据:1)。

  2. 然后我收到一些数据,并立即写一个响应,可用空间:1 和写入结果:41。

  3. 几乎立即 OutputStream 可以再次自由写入,可以发送数据:1(但我不需要发送任何内容,直到用户做出一些选择)。我很快就得到了回应。

  4. 最后,我尝试再次写入(2 秒后,因为那是用户做出选择的时间)。但是,现在 Space available 为 NO,Writing 结果为 0。

有任何想法吗?你建议我应该去哪里看?

提前致谢。

4

1 回答 1

0

我的指针变为零,因为我没有以正确的方式处理它们。

只是去展示我在 Objective-C 中的绿色程度。

于 2013-08-19T16:16:31.317 回答