调试项目代码时,发现了一个奇怪问题,记录如下:

非阻塞模式下,connect发起建链,返回-1(这在非阻塞模式下是很正常的现象)。然后将该socket的写事件进行监听,在写事件触发后,getsockopt函数获取错误(SO_ERROR)时,没有检测到发生错误(第四个参数返回0),最后在write操作时,发生错误。

原因:因配置文件的问题,导致得到的对端IP地址为空字符串"":

	struct sockaddr_in saddr;
saddr.sin_addr.s_addr = inet_addr("");
saddr.sin_family = AF_INET; /* "default" family */
saddr.sin_port = htons(22);

但是,在connect返回-1时,没有检测错误码是否为EINPROGRESS:

		if(connect(m_hSocket, pAddr, nAddrLen) == 0)
{
return true;
}
else
{
return false;
}

之后直接开始监听写事件。因为connect出错时,该socket套接字上的写连接已经关闭,所以写事件立即触发。

调用getsockopt时,获取的错误码为0,认为没有错误。

再接下来的write操作时,write写入一个已经关闭的连接,导致触发SIGPIPE信号。

总结:

虽然非阻塞模式下的connect,一般情况下都是返回-1,但是却忘了检测errno是否为EINPROGRESS,就像这个问题,因为地址写错了,connect返回-1,但是此时的错误却是"Network is unreachable",这种情况下就不能再监听该socket上的写事件,并在回调函数中调用getsockopt了,因为getsockopt得不到错误码,只会返回0。

最新文章

  1. Protobuf C#教程 ThriftC#教程大合辑
  2. 敏捷BI——岂止于快
  3. maven增加Spring
  4. 数据缓存iOS
  5. Flume用来收集日志,zeppelin用来展示
  6. 定位 - CoreLocation - 区域报警
  7. java编码问题深入总结
  8. syscomments 可以用来查找所有关于库中用到的某个关键词的所有相关脚本
  9. Git commit message和工作流规范
  10. Android 中与 so 有关的一个大坑
  11. linux打包压缩常用命令
  12. MySQL数据库实用技巧
  13. DeepLearning.ai学习笔记(五)序列模型 -- week1 循环序列模型
  14. JavaScript数组(三)数组对象使用整理
  15. 【Jetty】Jetty 的工作原理以及与 Tomcat 的比较
  16. [工具]Cobalt Strike 3.13 TeamServer for Windows
  17. 如何自出版一本书:定制 bookdown
  18. CCF——图像旋转201503-1
  19. AS开发实战第二章学习笔记——其他
  20. 软件工程第四周作业-PSP

热门文章

  1. linux下用eclipse开发mapreduce遇到的问题
  2. GVEdit中使用graphviz
  3. 跟我一起了解koa(三)
  4. Javascript-简单的倒计时跳转页面
  5. Eclipse:Eclipse插件开发全套教程
  6. 组件化开发之vue
  7. PYTHON网络爬虫与信息提取[网络爬虫协议](单元二)
  8. (转)Sql server中 如何用sql语句创建视图
  9. MySQL Daemon failed to start错误解决办法是什么呢?
  10. Vue--findIndex方法的使用原理