博客
关于我
第五章 基于TCP的服务器端/客户端(2)
阅读量:724 次
发布时间:2019-03-21

本文共 708 字,大约阅读时间需要 2 分钟。

TCP网络编程相关学习笔记

《TCP/IP网络编程》一书中,关于TCP套接字的I/O缓冲机制和数据传输机制的学习有些难度。特别是关于如何实现一个可靠的客户端和服务器之间的通信,需要深入理解TCP协议的原理。

主要学习了TCP协议的核心知识点,包括:

  • TCP套接字中的I/O缓冲特性
    • 每个TCP套接字都有自己独立的I/O缓冲区,缓冲区会在套接字创建时自动生成
    • 即使关闭套接字,输出缓冲中的数据仍会继续发送
    • 关闭套接字后,输入缓冲中的数据会丢失
    • 因此在开发多并发连接时需要注意缓冲区的分配与管理
    • write函数和read函数都不会等数据立即传输完成,需要理解其工作机制
    1. TCP的可靠传输机制
      • TCP会控制数据流的传输流量,避免出现缓冲溢出的风险
      • 数据传输过程中,数据包会被分配序号,发送方和接收方需要通过ACK确认接收状态
      • 如果收到某个数据包没有ACK,发送方会重转该数据包重新发送
      • 为此,TCP协议会启动计时器等待ACK应答,如果超时没有响应则实现数据包重转
      • 这些机制确保了数据能够可靠、完整地送达接收方
      1. TCP连接的建立与断开
        • TCP连接的建立采用三次握手机制
        • youngest也称为SYN+ACK序列,这是建立连接的第一步
        • 断开连接时会经历四次握手,双方各发送一次FIN报文
        • FIN报文的作用是通知通信对方可以关闭连接
        1. TCP数据交换的三次握手过程
          • 数据交换过程中发送方会持续发送数据包,接收方则通过ACK报文确认接收状态
          • 每次ACK号会增加传输的字节数,并且带有序号,以便接收方重建接收数据的顺序
          • 这样的机制确保了数据的完整性和有序性

          了解了这些TCP协议的实现细节,可以帮助更好地理解网络编程中的数据传输机制。

    转载地址:http://ipcgz.baihongyu.com/

    你可能感兴趣的文章
    Mysql5.6主从复制-基于binlog
    查看>>
    MySQL5.6忘记root密码(win平台)
    查看>>
    MySQL5.6的Linux安装shell脚本之二进制安装(一)
    查看>>
    MySQL5.6的zip包安装教程
    查看>>
    mysql5.7 for windows_MySQL 5.7 for Windows 解压缩版配置安装
    查看>>
    Webpack 基本环境搭建
    查看>>
    mysql5.7 安装版 表不能输入汉字解决方案
    查看>>
    MySQL5.7.18主从复制搭建(一主一从)
    查看>>
    MySQL5.7.19-win64安装启动
    查看>>
    mysql5.7.19安装图解_mysql5.7.19 winx64解压缩版安装配置教程
    查看>>
    MySQL5.7.37windows解压版的安装使用
    查看>>
    mysql5.7免费下载地址
    查看>>
    mysql5.7命令总结
    查看>>
    mysql5.7安装
    查看>>
    mysql5.7性能调优my.ini
    查看>>
    MySQL5.7新增Performance Schema表
    查看>>
    Mysql5.7深入学习 1.MySQL 5.7 中的新增功能
    查看>>
    Webpack 之 basic chunk graph
    查看>>
    Mysql5.7版本单机版my.cnf配置文件
    查看>>
    mysql5.7的安装和Navicat的安装
    查看>>