首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >SocketStream::read崩溃

SocketStream::read崩溃
EN

Stack Overflow用户
提问于 2017-12-14 20:19:16
回答 0查看 717关注 0票数 0

我们使用in NSInputStream从IMAP服务器接收数据。我们在Xcodes crash中看到了一个无法重现的stange崩溃。InputStream是这样初始化的(我省略了一些健全性检查):

代码语言:javascript
复制
- (void)getStreamsToServer:(NSString *)hostName
                   andPort:(NSUInteger)port
            andInputStream:(NSInputStream **)inputStream
           andOutputStream:(NSOutputStream **)outputStream
{
    CFReadStreamRef readStream = NULL;
    CFWriteStreamRef writeStream = NULL;
    CFStreamCreatePairWithSocketToHost(NULL,
                                       (__bridge CFStringRef)(hostName),
                                       (unsigned int)port,
                                       &readStream,
                                       &writeStream);

    *inputStream = (__bridge_transfer NSInputStream *)readStream;
    *outputStream = (__bridge_transfer NSOutputStream *)writeStream;
}

稍后,我们将流升级到SSL:

代码语言:javascript
复制
[_inputStream setProperty:NSStreamSocketSecurityLevelNegotiatedSSL
                   forKey:NSStreamSocketSecurityLevelKey];
[_outputStream setProperty:NSStreamSocketSecurityLevelNegotiatedSSL
                    forKey:NSStreamSocketSecurityLevelKey];

我们试着像这样读取数据:

代码语言:javascript
复制
NSUInteger READ_BUFFER_LENGTH = 16 * 1024;
uint8_t readBuffer[READ_BUFFER_LENGTH];
NSInteger readBytesCount = 0;
if([_inputStream hasBytesAvailable]) {
    readBytesCount = [_inputStream read:readBuffer
                              maxLength:READ_BUFFER_LENGTH];
    if (readBytesCount > 0) {
        NSData *partialData = [NSData dataWithBytes:(const void *)readBuffer
                                             length:readBytesCount];
}

这在99,99%的情况下都是有效的。但是Xcodes crash reporter给我们带来了一些令人头疼的崩溃:

代码语言:javascript
复制
0   CoreFoundation                  0x0000000184970620 CFHash + 360 (CFRuntime.c:1080)
1   CoreFoundation                  0x00000001849718b8 CFBasicHashGetCountOfKey + 160 (CFBasicHash.c:455)
2   CoreFoundation                  0x00000001849718b8 CFBasicHashGetCountOfKey + 160 (CFBasicHash.c:455)
3   CoreFoundation                  0x0000000184971804 CFSetContainsValue + 208 (CFSet.c:405)
4   CoreFoundation                  0x00000001849a0148 CFRunLoopRemoveSource + 164 (CFRunLoop.c:3542)
5   CFNetwork                       0x0000000185113e78 SocketStream::read(__CFReadStream*, unsigned char*, long, CFStreamError*, unsigned char*) + 604 (SocketStream.cpp:2757)
6   CoreFoundation                  0x000000018499c7c8 CFReadStreamRead + 480 (CFStream.c:1146)

这种崩溃发生在使用[NSData dataWithBytes:length:]的过程中。您是否有任何想法,如何激发,调试或修复这个错误?

EN

回答

页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/47813219

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档