zoukankan      html  css  js  c++  java
  • TCP可靠的传输机制

    TCP提供一种面向连接的、可靠的字节流服务。面向连接意味着两个使用TCP的应用(一般是一个客户和一个server)在彼此交换数据包之前必须先建立一个TCP连接。这一过程与打电话非常相似。先拨号振铃,等待对方摘机说“喂”。然后才说明是谁。在一个TCP连接中。仅有双方进行彼此通信。

    广播和多播不能用于TCP。

    TCP通过下列方式来提供可靠性:
    1.面向字节流和缓存机制:应用数据被切割成TCP觉得最适合发送的数据块。这和UDP全然不同,应用程序产生的数据长度将保持不变。由TCP传递给IP的信息单位称为报文段或段(segment)。
    2.超时重发和确认机制:当TCP发出一个段后,它启动一个定时器,等待目的端确认收到这个报文段。

    假设不能及时收到一个确认,将重发这个报文段。

    当TCP收到发自TCP连接还有一端的数据,它将发送一个确认。TCP有延迟确认的功能,在此功能没有打开,则是马上确认。功能打开,则由定时器触发确认时间点。

    3.检验和机制:TCP将保持它首部和数据的检验和。

    这是一个端到端的检验和。目的是检測数据在传输过程中的不论什么变化。

    假设收到段的检验和有差错,TCP将丢弃这个报文段和不确认收到此报文段(希望发端超时并重发)。

    4.字节编号机制:既然TCP报文段作为IP数据报来传输。而IP数据报的到达可能会失序。因此TCP报文段的到达也可能会失序。假设必要。TCP将对收到的数据进行又一次排序,将收到的数据以正确的顺序交给应用层。

    5.自己主动丢弃反复机制:既然IP数据报会发生反复。TCP的接收端必须丢弃反复的数据。
    6.流量控制:TCP还能提供流量控制。TCP连接的每一方都有固定大小的缓冲空间。TCP的接收端仅仅同意还有一端发送接收端缓冲区所能接纳的数据。

    这将防止较快主机致使较慢主机的缓冲区溢出。

    两个应用程序通过TCP连接交换8bit字节构成的字节流。TCP不在字节流中插入记录标识符。我们将这称为字节流服务(bytestreamservice)。

    假设一方的应用程序先传10字节,又传20字节,再传50字节。连接的还有一方将无法了解发方每次发送了多少字节。

    仅仅要自己的接收缓存没有塞满,TCP 接收方将有多少就收多少。一端将字节流放到TCP连接上,相同的字节流将出如今TCP连接的还有一端。

    其他,TCP字节流中没有任何解释的内容,无论。TCP我不知道所发送的数据字节的二进制数据流。仍是ASCⅡ字符、EBCDIC字符,或其他类型的数据。

    由该字节流的解释TCP连接所述应用层解释的两侧。

  • 相关阅读:
    visual studio(vs)中项目解决方案的目录组织安排
    vs2017如果在调试状态下查看QString等qt变量的值
    终于成功编译和运行了glc_player和glc_lib
    Visual Studio(vs)内存泄漏Detected memory leaks的解决方案
    std::max、std::min error C2589: “(”:“::”右边的非法标记,error C2059:&nbs
    c++跨动态库DLL的内存分配与释放问题2
    CABasicAnimation精讲
    CAAnimation解读
    iOS CAShapeLayer精讲
    UIBezierPath精讲
  • 原文地址:https://www.cnblogs.com/gcczhongduan/p/5028129.html
Copyright © 2011-2022 走看看