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支持更简单的、快速的、点对点的数据报模式。

两类传输协议: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支持更简单的、快速的、点对点的数据报模式。

原文地址:https://www.cnblogs.com/huangjianping/p/8325722.html

时间: 2024-12-03 13:08:09

Java 网络编程(二) 两类传输协议:TCP UDP的相关文章

Java网络编程基础(六)— 基于TCP的NIO简单聊天系统

在Java网络编程基础(四)中提到了基于Socket的TCP/IP简单聊天系统实现了一个多客户端之间护法消息的简单聊天系统.其服务端采用了多线程来处理多个客户端的消息发送,并转发给目的用户.但是由于它是基于Socket的,因此是阻塞的. 本节我们将通过SocketChannel和ServerSocketChannel来实现同样的功能. 1.客户端输入消息的格式 username:msg    username表示要发送的的用户名,msg为发送内容,以冒号分割 2.实现思路 实现思路与Java网络

Java网络编程二:Socket详解

Socket又称套接字,是连接运行在网络上两个程序间的双向通讯的端点. 一.使用Socket进行网络通信的过程 服务端:服务器程序将一个套接字绑定到一个特定的端口,并通过此套接字等待和监听客户端的连接请求. 客户端:客户端程序根据你服务器所在的主机名和端口号发出连接请求. 两者之间的通信是通过Socket完成的,我们可以认为Socket是两个城市之间的交通工具,有了它,就可以在两个城市之间穿梭了. Socket通信示例 主机A的应用程序和主机B的应用程序通信,必须通过Socket建立连接,而建立

java网络编程:InteAddress类API

apache的http协议jar地址:http://hc.apache.org/downloads.cgi 类 InetAddress java.lang.Object java.net.InetAddress 所有已实现的接口: Serializable 直接已知子类: Inet4Address, Inet6Address 此类表示互联网协议 (IP) 地址.IP 地址是 IP 使用的 32 位或 128 位无符号数字,它是一种低级协议,UDP 和 TCP 协议都是在它的基础上构建的.Inet

两类传输协议:TCP,UDP

1) TCP是Transfer Control Protocol的简称,是一种面向连接的保证可靠传输的协议.通过TCP协议传输,得到的是一个顺序的无差错的数据流.发送方和接收方的成对的两个socket之间必须建立连接,以便在TCP协议的基础上进行通信,当一个socket(通常都是server socket)等待建立连接时,另一个socket可以要求进行连接,一旦这两个socket连接起来,它们就可以进行双向数据传输,双方都可以进行发送或接收操作.[这是一种典型的服务端与客户端进行交互的模型] T

Java网络编程:OSI七层模型和TCP/IP模型介绍

OSI(Open System Interconnection),开放式系统互联参考模型 .是一个逻辑上的定义,一个规范,它把网络协议从逻辑上分为了7层.每一层都有相关.相对应的物理设备,比如常规的路由器是三层交换设备,常规的交换机是二层交换设备.OSI七层模型是一种框架性的设计方法,建立七层模型的主要目的是为解决异种网络互连时所遇到的兼容性问题,其最主要的功能就是帮助不同类型的主机实现数据传输.它的最大优点是将服务.接口和协议这三个概念明确地区分开来,通过七个层次化的结构模型使不同的系统不同的

Java 网络编程(二)

以下例开始本文的内容: 例1,需求:上传图片. 客户端: 服务端点. 读取客户端已有的图片数据. 通过socket输出流将数据发给服务端. 读取服务端反馈信息. 关闭. class PicClient { public static void main(String[] args) throws IOException { /* * 一系列判断 */ if(args.length != 1) { System.out.println("请选择一个jpg格式的图片"); return;

Java网络编程基础(四)---基于TCP的简单聊天系统

实现思路: 要实现消息的发送,客户端每次在连接服务器端时都需要告诉服务器自己的用户名,以便能够接收到发送给自己的消息.服务器端在接收到消息时,能够查到对应用户名的客户端,将消息发送给该客户端. 服务端需要实现多个客户端的同时请求,因此需要使用多线程来处理客户端的请求.同时,它还需要保存一份用户名列表,以便在转发消息时能够查找到对应的用户. 对于客户端来说,客户端需要能够随时收取服务器端转发来的消息,并能够随时通过键盘输入发送消息,因此它的读取消息和发送消息功能是并行的,需要独立的线程来实现. 实

关于Java网络编程

一,网络编程中两个主要的问题 一个是如何准确的定位网络上一台或多台主机,另一个就是找到主机后如何可靠高效的进行数据传输. 在TCP/IP协议中IP层主要负责网络主机的定位,数据传输的路由,由IP地址可以唯一地确定Internet上的一台主机. 而TCP层则提供面向应用的可靠(tcp)的或非可靠(UDP)的数据传输机制,这是网络编程的主要对象,一般不需要关心IP层是如何处理数据的. 目前较为流行的网络编程模型是客户机/服务器(C/S)结构.即通信双方一方作为服务器等待客户提出请求并予以响应.客户则

Java 网络编程(转)

一,网络编程中两个主要的问题 一个是如何准确的定位网络上一台或多台主机,另一个就是找到主机后如何可靠高效的进行数据传输. 在TCP/IP协议中IP层主要负责网络主机的定位,数据传输的路由,由IP地址可以唯一地确定Internet上的一台主机. 而TCP层则提供面向应用的可靠(tcp)的或非可靠(UDP)的数据传输机制,这是网络编程的主要对象,一般不需要关心IP层是如何处理数据的. 目前较为流行的网络编程模型是客户机/服务器(C/S)结构.即通信双方一方作为服务器等待客户提出请求并予以响应.客户则