UDP和TCP浅析

UDP协议全称是用户数据报协议,在网络中它与TCP协议一样用于处理数据包,是一种无连接的协议。

在选择使用协议的时候,选择UDP必须要谨慎。在网络质量令人十分不满意的环境下,UDP协议数据包丢失会比较严重。但是由于UDP的特性:它不属于连接型协议,因而具有资源消耗小,处理速度快的优点,所以通常音频、视频和普通数据在传送时使用UDP较多,因为它们即使偶尔丢失一两个数据包,也不会对接收结果产生太大影响。比如我们聊天用的ICQ和QQ就是使用的UDP协议。

java.net.InetAddress类:此类表示互联网协议 (IP) 地址。

静态方法:
static InetAddress getLocalHost() 返回本地主机(你自己的使用的电脑)。
static InetAddress getByName(String host) 在给定主机名的情况下确定主机的 IP 地址。
非静态方法:
String getHostAddress() 返回 IP 地址字符串(以文本表现形式)。
String getHostName() 获取此 IP 地址的主机名。

UDP通信的接收端:接收发送端发送的数据报包,拆包
* 和udp相关的类:
* java.net.DatagramPacket:此类表示数据报包。
* 作用:使用数据报包,接收发送端的数据
* java.net.DatagramSocket:此类表示用来发送和接收数据报包的套接字。
* 作用:发送数据报包,接收数据报包
* 套接字:绑定IP地址和端口号的网络对象
*
* 构造方法:
* DatagramPacket(byte[] buf, int length)
* 构造 DatagramPacket,用来接收长度为 length 的数据包。
* DatagramSocket(int port)
* 创建数据报套接字并将其绑定到本地主机上的指定端口。
*
* 成员方法:
* void receive(DatagramPacket p) 从此套接字接收数据报包。
*
* 实现步骤:
* 1.创建DatagramPacket对象,接收发送端的数据报
* 2.创建DatagramSocket对象,并且和系统要指定的端口号
* 3.使用DatagramSocket中的方法receive发送端接收数据报包
* 4.拆包
* DatagramPacket有和数据报包相关的方法
* int getLength() 获取发送端数据的长度
* InetAddress getAddress() 获取发送端的IP地址对象
* int getPort() 获取发送端的端口号(系统随机分配的)
* 5.释放资源

 1 public static void main(String[] args) throws IOException {
 2         //1.创建DatagramPacket对象,接收发送端的数据报
 3         byte[] bytes = new byte[1024];//数据最大传输64kb  1024*64
 4         DatagramPacket dp = new DatagramPacket(bytes, bytes.length);
 5         //2.创建DatagramSocket对象,并且和系统要指定的端口号
 6         DatagramSocket ds = new DatagramSocket(8888);
 7         //3.使用DatagramSocket中的方法receive发送端接收数据报包
 8         ds.receive(dp);
 9         //4.拆包
10         //int getLength()  获取发送端数据的长度
11         int length = dp.getLength();
12         //InetAddress getAddress() 获取发送端的IP地址对象
13         String ip = dp.getAddress().getHostAddress();
14         //int getPort()  获取发送端的端口号(系统随机分配的)
15         int port = dp.getPort();
16
17         System.out.println(new String(bytes,0,length)+"ip:"+ip+",端口号"+port);
18         //5.释放资源
19         ds.close();
20     }

UDP通信的发送端:把数据进行包装,根据接收端的IP地址和端口发送数据报包
*
* 和udp相关的类:
* java.net.DatagramPacket:此类表示数据报包。
* 作用:把数据和接收端的IP地址,端口号进行包装
* java.net.DatagramSocket:此类表示用来发送和接收数据报包的套接字。
* 作用:发送数据报包,接收数据报包
* 套接字:绑定IP地址和端口号的网络对象
*
* 构造方法:
* DatagramPacket(byte[] buf, int length, InetAddress address, int port)
* 构造数据报包,用来将长度为 length 的包发送到指定主机上的指定端口号。
* DatagramSocket()
* 构造数据报套接字并将其绑定到本地主机上任何可用的端口。
*
* 成员方法:
* void send(DatagramPacket p) 从此套接字发送数据报包。
*
* 实现步骤:
* 1.创建DatagramPacket对象,封装数据和接收端的IP地址,端口号(创建集装箱)
* 2.创建DatagramSocket对象(创建码头)
* 3.使用DatagramSocket中的方法send发送数据报包
* 4.释放资源
*
* UDP通信是面向无连接:不用管是否有接收端,都可以发送数据,没有接收端会发生数据丢失

 1 public static void main(String[] args) throws IOException {
 2         //1.创建DatagramPacket对象,封装数据和接收端的IP地址,端口号(创建集装箱)
 3         byte[] bytes = "你好UDP!".getBytes();
 4         InetAddress address = InetAddress.getByName("127.0.0.1");
 5         DatagramPacket dp = new DatagramPacket(bytes, bytes.length, address, 8888);
 6         //2.创建DatagramSocket对象(创建码头)
 7         DatagramSocket ds = new DatagramSocket();
 8         //3.使用DatagramSocket中的方法send发送数据报包
 9         ds.send(dp);
10         //4.释放资源
11         ds.close();
12     }

TCP是面向连接的通信协议,通过三次握手建立连接,通讯完成时要拆除连接,由于TCP是面向连接的所以只能用于端到端的通讯。

TCP通信的客户端:向服务器发送请求连接,接收服务器回写的数据
*
* 表示客户端的类:
* java.net.Socket:此类实现客户端套接字(也可以就叫“套接字”)。
*
* 构造方法:
* Socket(InetAddress address, int port) 创建一个流套接字并将其连接到指定 IP 地址的指定端口号。
* Socket(String host, int port) 创建一个流套接字并将其连接到指定主机上的指定端口号。
*
* 成员方法:
* OutputStream getOutputStream() 返回此套接字的输出流。
* InputStream getInputStream() 返回此套接字的输入流。
*
* 注意:客户端和服务器进行数据交互,不能使用自己创建的流对象,必须使用Socket中提供的流
*
* 实现步骤:
* 1.创建客户端Socket对象,绑定服务器的IP地址和端口号
* 2.使用Socket中的方法getOutputStream获取网络输出流
* 3.使用OutputStream网络流中的方法write给服务器发送数据
* 4.使用Socket中的方法getInputStream获取网络输入流
* 5.使用InputStream网络流中的方法read读取服务器回写的数据
* 6.释放资源
*
* 注意:TCP是面向连接通信,必须先启动服务器,在启动客户端,如果服务器没有启动
* 则会抛出ConnectException: Connection refused: connect

 1 public static void main(String[] args) throws IOException {
 2         //1.创建客户端Socket对象,绑定服务器的IP地址和端口号
 3         Socket socket = new Socket("127.0.0.1", 9999);
 4         //2.使用Socket中的方法getOutputStream获取网络输出流
 5         OutputStream os = socket.getOutputStream();
 6         //3.使用OutputStream网络流中的方法write给服务器发送数据
 7         os.write("你好服务器".getBytes());
 8         //4.使用Socket中的方法getInputStream获取网络输入流
 9         InputStream is = socket.getInputStream();
10         //5.使用InputStream网络流中的方法read读取服务器回写的数据
11         byte[] bytes = new byte[1024];
12         int len = is.read(bytes);
13         System.out.println(new String(bytes,0,len));
14         //6.释放资源
15         socket.close();
16     }

TCP通信的服务器端:接收客户端的发送的数据,给客户端回写数据
*
* 表示服务器的类:
* java.net.ServerSocket:此类实现服务器套接字。
*
* 构造方法:
* ServerSocket(int port) 创建绑定到特定端口的服务器套接字。
*
* 有一件特别重要的事:服务器必须的知道是哪个客户端请求的服务器
* 所有可以使用accept方法获取请求的客户端
* 成员方法:
* Socket accept() 侦听并接受到此套接字的连接。
*
* 实现步骤:
* 1.创建ServerSocket对象,和系统要指定的端口号
* 2.使用ServerSocket中的方法accept获取请求的客户端对象
* 3.使用Socket中的方法getInputStream获取网络输入流
* 4.使用InputStream网络流中的方法read读取客户端发送的数据
* 5.使用Socket中的方法getOutputStream获取网络输出流
* 6.使用OutputStream网络流中的方法write给客户端回写数据
* 7.释放资源(ServerSocket,Socket)

 1 public static void main(String[] args) throws IOException {
 2         //1.创建ServerSocket对象,和系统要指定的端口号
 3         ServerSocket server = new ServerSocket(9999);
 4         //2.使用ServerSocket中的方法accept获取请求的客户端对象
 5         Socket socket = server.accept();
 6         //3.使用Socket中的方法getInputStream获取网络输入流
 7         InputStream is = socket.getInputStream();
 8         byte[] bytes = new byte[1024];
 9         //4.使用InputStream网络流中的方法read读取客户端发送的数据
10         int len = is.read(bytes);
11         System.out.println(new String(bytes,0,len));
12         //5.使用Socket中的方法getOutputStream获取网络输出流
13         OutputStream os = socket.getOutputStream();
14         //6.使用OutputStream网络流中的方法write给客户端回写数据
15         os.write("收到".getBytes());
16         //7.释放资源(ServerSocket,Socket)
17         socket.close();
18         server.close();
19     }
时间: 2024-08-14 14:53:08

UDP和TCP浅析的相关文章

移动端IM系统的协议选型:UDP还是TCP?

1.前言 对于有过网络编程经验的开发者来说,使用何种数据传输层协议来实现数据的通信,是个非常基础的问题,它涉及到你的第一行代码该如何编写. 从PC时代的IM开始,IM开发者就在为数据传输协议的选型争论不休(比如:<为什么QQ用的是UDP协议而不是TCP协议?>这样的问题,隔一段时间就能在社区里看到).到了移动互联网时代,鉴于移动网络的不可靠性等特点,再加上手机的省电策略.流量压缩等,为这个问题的回答增了更多的不确定因素. 对于有选择困难证的人来说,基于以上因素,加上UDP和TCP协议的本质差异

Java之网络编程UDP和TCP

注*部分转来的 第1章 网络通信协议 通过计算机网络可以使多台计算机实现连接,位于同一个网络中的计算机在进行连接和通信时需要遵守一定的规则,这就好比在道路中行驶的汽车一定要遵守交通规则一样.在计算机网络中,这些连接和通信的规则被称为网络通信协议,它对数据的传输格式.传输速率.传输步骤等做了统一规定,通信双方必须同时遵守才能完成数据交换. 网络通信协议有很多种,目前应用最广泛的是TCP/IP协议(Transmission Control Protocal/Internet Protoal传输控制协

JAVA基础学习day24--Socket基础一UDP与TCP的基本使用

一.网络模型 1.1.OIS参考模型 1.2.TCP/IP参考模型 1.3.网络通讯要素 IP地址:IPV4/IPV6 端口号:0-65535,一般0-1024,都被系统占用,mysql:3306,oracle:1521 传输协议:TCP/UDP 二.类 InetAddress 2.1.InetAddress 主机对象 IP 地址是 IP 使用的 32 位或 128 位无符号数字,它是一种低级协议,UDP 和 TCP 协议都是在它的基础上构建的 2.2.示例 import java.net.*;

UDP与TCP数据包的延迟探测系统

最近需要测试Akamai的几个节点对数据包加速加速效果,下面是win32上面的一个udp.tcp ping的探测程序. 程序参考了http://www.tenouk.com/Winsock/Winsock2example9.html中的代码. 下面是系统的原理图: 由于udp的特殊性,采用在应用层添加seq的方案,保证回包的准确性(经过测试发现,nmap项目的nping探测器由于没有进行回包准确性的验证,导致最后的统计数据错误,朋友们应该注意). 而tcp本身就是一种数据流而已,它的机制导致了粘

基于Socket的UDP和TCP编程介绍

一.概述 TCP(传输控制协议)和UDP(用户数据报协议是网络体系结构TCP/IP模型中传输层一层中的两个不同的通信协议. TCP:传输控制协议,一种面向连接的协议,给用户进程提供可靠的全双工的字节流,TCP套接口是字节流套接口(streamsocket)的一种. UDP:用户数据报协议.UDP是一种无连接协议.UDP套接口是数据报套接口(datagram socket)的一种. 二.TCP和UDP介绍 1)基本TCP客户—服务器程序设计基本框架 说明:(三路握手)         1.客户端发

UDP和TCP的比较

当客户端需要请求数据库服务器上的某些数据时,它至少需要三个数据报来建立TCP连接,三个数据报礼发送和确认少量数据,三个用来关闭连接.然而,如果使用UDP的话,仅仅需要发出两个数据报就能达到相同的效果.UDP不需要客户端建立和关闭与服务器的连接.客户端只是将数据放到数据报中并发给服务器.服务器构造出应答,并将应答数据放到去往客户端的数据报中,然后再发送给客户端.尽管对于简单实事务来说,这种数据传输方式与TCP相比,既快又有效,但UDP不能处理数据报丢失.UDP允许应用于远程计算机特定端口上的服务联

UDP和TCP的区别(转)

TCP协议与UDP协议的区别    首先咱们弄清楚,TCP协议和UCP协议与TCP/IP协议的联系,很多人犯糊涂了,一直都是说TCP/IP协议与UDP协议的区别,我觉得这是没有从本质上弄清楚网络通信!TCP/IP协议是一个协议簇.里面包括很多协议的.UDP只是其中的一个.之所以命名为TCP/IP协议,因为TCP,IP协议是两个很重要的协议,就用他两命名了.TCP/IP协议集包括应用层,传输层,网络层,网络访问层.其中应用层包括:超文本传输协议(HTTP):万维网的基本协议.   文件传输(TFT

【iOS与EV3混合机器人编程系列之四】iOS_WiFi_EV3_Library 剖析之中的一个:WiFi UDP和TCP

在上一篇文章中.我们通过编写EV3 Port Viewer项目实现了iOS监測EV3的实时端口数据. 程序最核心的部分就是我们的开源码库iOS_WiFi_EV3_Library. 那么,在本文中,我们将具体介绍我们这个库的编写.为了完毕这个库,本人參考了网上许多资料,主要包括EV3的源码,win版本号的代码库以及Monobrick相关以及网上的各种资料,在此就不一一列举了. 因为水平有限,本代码库还存在各种问题,望使用的读者见谅. 大家也能够在这个基础之上自己进行改造完好. 为了具体说明代码库的

DNS同时占用UDP和TCP端口53——传输数据超过512时候用tcp,DNS服务器可以配置仅支持UDP查询包

DNS同时占用UDP和TCP端口53是公认的,这种单个应用协议同时使用两种传输协议的情况在TCP/IP栈也算是个另类.但很少有人知道DNS分别在什么情况下使用这两种协议. 先简单介绍下TCP与UDP.     TCP是一种面向连接的协议,提供可靠的数据传输,一般服务质量要求比较高的情况,使用这个协议.UDP---用户数据报协议,是一种无连接的传输层协议,提供面向事务的简单不可靠信息传送服务. TCP与UDP的区别:     UDP和TCP协议的主要区别是两者在如何实现信息的可靠传递方面不同.TC