zoukankan
html css js c++ java
关于tcp send的再次思考
最近在用socket时,再次思考了一下如何确保对方收到消息的问题
下面是一些不错的回答
https://www.zhihu.com/question/25016042/answer/73785738
其实我已经说得很清楚了,其实就相当于文件传输的断点续传。你没有必要每次send成功后,去等待服务端发回一个信息(其实你也可以这么做,不过效率比较低),你可以这么做,如果send返回错误,你关掉连接后重新连接,等待对方发出已收到字节数的通知,然后,你再确定从何处开始发送,最后,如果你已经发完,也必须等待对方发出已经收完的通知,这样你可以确保你的文件的正确接收。
我这里只是讲了大致过程,不过要点都讲了,具体的实施,我想并不困难.
我想,你所谓的send成功指的是接收方已经发出了确认信息,事实上,你没有必要知道这些信息,因为tcp层本身就有校验,确认机制,如果出现异常,send或者closesocket就会及时返回错误的,因为tcp底层有确认机制,在数据没有正确发出前,他是不可能把数据扔掉的,他会不断的发送,接受应答,直到数据正确接收,或者他认为已经出现异常时为止,如果他认为已经出现异常,在你调用send或者closesocket时会返回一个错误信息
总之,tcp会保证数据正确有序的到达,但是,他不会也不可能去处理异常,它的这种保证也仅限于tcp层,因此,你的程序仍有必要在作一些确认
查看全文
相关阅读:
python2.7打印中文乱码的问题解决
Tesseract5.0训练字库,提高OCR特殊场景识别率(一)
git比较重要但是又容易忘记的操作
ntp局域网时间同步操作
Flask使用原生sql语句
Linux的tail命令查看文件
使用gitlab的webhook进行前端自动部署
通过queue实现前端的被动接收
互动interactive与多行输出
复习
原文地址:https://www.cnblogs.com/wangshaowei/p/11822784.html
最新文章
k8s入坑之路(9)k8s网络插件详解
k8s入坑之路(8)kube-proxy详解
k8s入坑之路(7)kubernetes设计精髓List/Watch机制和Informer模块详解
k8s入坑之路(6)kube-controller-manager详解
k8s入坑之路(5)kube-apiserver详解
k8s入坑之路(4)kubenetes安装
k8s入坑之路(3)containerd容器
k8s入坑之路(2)kubernetes架构详解
kubernetes集群系列资料02---koolshare部署
kubernetes集群系列资料01---K8S基础知识
热门文章
K8S---harbor故障处理
K8S部署---故障处理
K8S集群安装故障排查
linux故障处理--系统故障
软路由koolshare故障处理集锦
Linux系统---硬盘性能测试
windows安全加固
Linux安全加固
pycharm中的Terminal 中无法使用git的问题
Tesseract5.0训练字库,提高OCR特殊场景识别率,合并字库(二)
Copyright © 2011-2022 走看看
我这里只是讲了大致过程,不过要点都讲了,具体的实施,我想并不困难.
总之,tcp会保证数据正确有序的到达,但是,他不会也不可能去处理异常,它的这种保证也仅限于tcp层,因此,你的程序仍有必要在作一些确认