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层,因此,你的程序仍有必要在作一些确认
查看全文
相关阅读:
梦断代码阅读笔记之二
《需求工程——软件建模与分析》阅读笔记之四
阿里云HttpDns接入
Android电量优化-Battery Historian环境搭建及简单使用
Crash监控的简单实现方案
Flutter——比RichText更好用的富文本
用终端命令行工具iTerm创建flutter项目
Flutter——打包到TestFlight和安卓
Flutter——数组以符号隔开转字符串
某信反反越狱
原文地址:https://www.cnblogs.com/wangshaowei/p/11822784.html
最新文章
C++设计模式——单例类
ellipsize_end textview
FoldTextView
位运算
Redis 持久化实践
Kafka学习系列----- 生产者、分区、消费者的关系
SpringDI
Mysql 数据恢复实战 (Win & Liunx 版本)
数据库-联合索引
SpringIOC浅析
热门文章
Redis 哨兵原理浅析
领域模型开发DDD
Kafka学习系列----- Kafka 的副本是个啥?
搭建nginx+rtmp本地模拟推流
UISegmentedControl某一项标题文字显示不全的坑
Docker 下 Prometheus + Grafana + Exporter 配置
GRPC使用篇
android webview 网页,小公司更新策略
《梦断代码》阅读笔记之三
《梦断代码》阅读笔记之一
Copyright © 2011-2022 走看看
我这里只是讲了大致过程,不过要点都讲了,具体的实施,我想并不困难.
总之,tcp会保证数据正确有序的到达,但是,他不会也不可能去处理异常,它的这种保证也仅限于tcp层,因此,你的程序仍有必要在作一些确认