有了 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 和写入结果:41。
几乎立即 OutputStream 可以再次自由写入,可以发送数据:1(但我不需要发送任何内容,直到用户做出一些选择)。我很快就得到了回应。
最后,我尝试再次写入(2 秒后,因为那是用户做出选择的时间)。但是,现在 Space available 为 NO,Writing 结果为 0。
有任何想法吗?你建议我应该去哪里看?
提前致谢。