zoukankan      html  css  js  c++  java
  • Java 网络编程(二) 两类传输协议:TCP UDP

     

    两类传输协议:TCP,UDP

     

    TCP

      TCP是Transfer Control Protocol(传输控制协议)的简称,是一种面向连接的保证可靠传输的协议

      在TCP/IP协议中,

      IP层主要负责网络主机的定位,数据传输的路由,由IP地址可以唯一确定Internet上的一台主机

      而TCP层则提供面向应用的可靠的或非可靠的数据传输机制,这是网络编程的主要对象,一般不需要关心IP层是如何处理数据的。

      通过TCP协议传输,得到的是一个顺序的无差错的数据流。

      发送方和接收方的成对的两个socket之间必须建立连接,以便在TCP协议的基础上进行通信。

      当一个socket(通常都是server socket)等待建立连接时,另一个socket可以要求进行连接,一旦这两个socket连接起来,它们就可以进行双向数据传输,双方都可以进行发送或接收操作。

      TCP是一个基于连接的协议,它能够提供两台计算机之间的可靠的数据流。

      HTTP、FTP、Telnet等应用都需要这种可靠的通信通道。

     

    UDP

      UDP是User Datagram Protocol的简称,是一种无连接的协议

      UDP是从一台计算机向另一台计算机发送称为数据报的独立数据包的协议,该协议并不保证数据报是否能正确地到达目的地,它是一个非面向连接的协议。

      每个数据报都是一个独立的信息,包括完整的源地址或目的地址,它在网络上以任何可能的路径传往目的地,因此能否到达目的地,到达时间以及内容的正确性都是不能保证的。

     

    TCP和UDP的比较

      使用UDP时,每个数据报中都给出了完整的地址信息,因此无需建立发送方和接收方的连接

      对于TCP协议,由于它是一个面向连接的协议,在socket之间进行数据传输之前必然要建立连接,所以在TCP中多了一个连接建立的时间。

      使用UDP传输数据时是有大小限制的,每个被传输的数据报必须限定在64KB之内。

      TCP没有这方面的限制,一旦连接建立起来,双方的socket就可以按统一的格式传输大量的数据

      UDP是一个不可靠的协议,发送方所发送的数据报并不一定以相同的次序到达接收方。

      TCP是一个可靠的协议,它确保接收方完全正确地获取发送方所发送的全部数据。

      可靠的传输是要付出代价的,对数据内容正确性的检验必然占用计算机的处理时间和网络的带宽。因此TCP传输的效率不如UDP高

      TCP在网路通信上有极强的生命力,例如远程连接(Telnet)和文件传输(FTP)都需要不定长度的数据被可靠地传输。

      相比之下UDP操作简单,而且仅需要较少的监护,因此通常用于局域网高可靠性的分散系统中client/server应用程序。

      

      此处推荐书籍《TCP/IP详解》,分三卷。

    TCP/IP模型

      TCP/IP模型包括四个层次:

      应用层

      传输层

      网络层

      网络接口

      TCP/IP与OSI参考模型的对应关系:

      

    JDK中的网络类

      通过java.net包中的类,java程序能够使用TCP或UDP协议在互联网上进行通讯。

      Java通过扩展已有的流式输入/输出接口增加在网络上建立输入/输出对象特性这两个方法支持TCP/IP。

      Java支持TCP和UDP协议族。

      TCP用于网络的可靠的流式输入/输出。

      UDP支持更简单的、快速的、点对点的数据报模式。

    参考资料

      圣思园张龙老师Java SE系列视频教程。

  • 相关阅读:
    hbase性能调优_表设计案例
    ItemCF_基于物品的协同过滤_MapReduceJava代码实现思路
    TF-IDF_MapReduceJava代码实现思路
    Hive HQL学习
    一对多(多对一)关系中的inverse和cascade属性
    Hive_UDF函数中集合对象初始化的注意事项
    kafka producer生产数据到kafka异常:Got error produce response with correlation id 16 on topic-partition...Error: NETWORK_EXCEPTION
    Kafka中操作topic时 Error:Failed to parse the broker info from zookeeper
    keepalived VS zookeeper
    算法--链表的回文结构
  • 原文地址:https://www.cnblogs.com/mengdd/p/2951841.html
Copyright © 2011-2022 走看看