import java.io.IOException;
import java.net.DatagramPacket;
import java.net.DatagramSocket;
import java.net.InetAddress; class UDPClient
{
public static void main(String[] args) throws IOException
{
// 构造数据报套接字并将其绑定到本地主机上任何可用的端口
DatagramSocket client = new DatagramSocket();
// 在给定主机名的情况下确定主机的 IP 地址
InetAddress addr = InetAddress.getByName("127.0.0.1");
int port = 10021;
for (int i = 0; i < 5; i++)
{
String sendStr = "Hello! I'm Client" + i;
byte[] sendBuf = sendStr.getBytes(); // 构造数据报包,用来将长度为 length 的包发送到指定主机上的指定端口号。length 参数必须小于等于 buf.length。
// buf - 包数据 length - 包长度 address - 目的地址 port - 目的端口号
DatagramPacket sendPacket = new DatagramPacket(sendBuf, sendBuf.length, addr, port); // 从此套接字发送数据报包。DatagramPacket 包含的信息指示:将要发送的数据、其长度、远程主机的 IP
// 地址和远程主机的端口号。
client.send(sendPacket); byte[] recvBuf = new byte[100]; // 构造 DatagramPacket,用来接收长度为 length 的数据包。 length 参数必须小于等于
// buf.length。
DatagramPacket recvPacket = new DatagramPacket(recvBuf, recvBuf.length); // 从此套接字接收数据报包。
client.receive(recvPacket);
String recvStr = new String(recvPacket.getData(), 0, recvPacket.getLength());
System.out.println("recvMsg =" + recvStr +"; remotePort =" + recvPacket.getPort());
} client.close();
}
}

  

import java.io.IOException;
import java.net.DatagramPacket;
import java.net.DatagramSocket;
import java.net.InetAddress; class UDPServer
{
public static void main(String[] args) throws IOException
{
DatagramSocket server = new DatagramSocket(10021);
byte[] recvBuf = new byte[100];
for (int i = 0; i < 5; i++)
{
DatagramPacket recvPacket = new DatagramPacket(recvBuf, recvBuf.length);
server.receive(recvPacket);
String recvStr = new String(recvPacket.getData(), 0, recvPacket.getLength());
int port = recvPacket.getPort();
System.out.println("reveMsg = "+ recvStr + "; remote port =" + port); InetAddress addr = recvPacket.getAddress();
String sendStr = "Hello ! I'm Server" + i; byte[] sendBuf = sendStr.getBytes();
DatagramPacket sendPacket = new DatagramPacket(sendBuf, sendBuf.length, addr, port); server.send(sendPacket);
} server.close();
}
}

client端输出:

recvMsg =Hello ! I'm Server0; remotePort =10021
recvMsg =Hello ! I'm Server1; remotePort =10021
recvMsg =Hello ! I'm Server2; remotePort =10021
recvMsg =Hello ! I'm Server3; remotePort =10021
recvMsg =Hello ! I'm Server4; remotePort =10021

server端输出:

reveMsg = Hello! I'm Client0; remote port =61226
reveMsg = Hello! I'm Client1; remote port =61226
reveMsg = Hello! I'm Client2; remote port =61226
reveMsg = Hello! I'm Client3; remote port =61226
reveMsg = Hello! I'm Client4; remote port =61226

UDP运输层协议:

(1)UDP是一种无连接的服务,即在两个进程间没有创建管道时的初始握手阶段。

(2)因为UDP没有管道,所以当一个进程需要向另一个进程发送一批字节时,该发送进程需要为这批字节附上目的进程地址(IP和port),并且,该过程对于每批由发送进程所发送的字节都必须重复做,见循环中五次发送UDP报文的操作。

由于UDP当中没有流与套接字相关联,事实上UDP也不是将字节送入与Socket相关的流,而是将一个个分组通过DataGramSocket对象直接发送出去。

而在TCP运输层协议中:

(1)TCP在客户机进程和服务机进程之间提供了可靠的字节流服务,一旦建立连接,两端就可以通过与Socket对象相关联的输入输出流来进行数据交互,而不用像UDP那样每次都要通过DataGramSocket对象指明远端IP和port来发送和接收

import java.io.IOException;
import java.io.InputStream;
import java.io.OutputStream;
import java.net.InetAddress;
import java.net.InetSocketAddress;
import java.net.Socket; class TCPClient
{
public static void main(String[] args) throws IOException
{
// 构造数据报套接字并将其绑定到本地主机上任何可用的端口
Socket client = new Socket();
// 在给定主机名的情况下确定主机的 IP 地址
InetAddress addr = InetAddress.getByName("127.0.0.1");
int port = 10021;
client.connect(new InetSocketAddress(addr, port));
OutputStream output = client.getOutputStream();
InputStream input = client.getInputStream();
for (int i = 0; i < 5; i++)
{
String sendStr = "Hello! I'm Client" + i; output.write(sendStr.getBytes()); byte[] recvBuf = new byte[100]; int length = input.read(recvBuf);
String str = new String(recvBuf);
System.out.println("recvMsg =" + str.substring(0,length));
} client.close();
}
}
import java.io.IOException;
import java.io.InputStream;
import java.io.OutputStream;
import java.net.ServerSocket;
import java.net.Socket; class TCPServer
{
public static void main(String[] args) throws IOException
{
ServerSocket server = new ServerSocket(10021);
Socket socket = server.accept();
OutputStream output = socket.getOutputStream();
InputStream input = socket.getInputStream();
byte[] recvBuf = new byte[100];
for (int i = 0; i < 5; i++)
{
int len = input.read(recvBuf);
String str = new String(recvBuf); System.out.println("reveMsg = "+ str.substring(0,len) + "; remote port =" + socket.getRemoteSocketAddress()); String sendStr = "Hello ! I'm Server" + i; output.write(sendStr.getBytes());
} server.close();
}
}

client端输出:

recvMsg =Hello ! I'm Server0
recvMsg =Hello ! I'm Server1
recvMsg =Hello ! I'm Server2
recvMsg =Hello ! I'm Server3
recvMsg =Hello ! I'm Server4

server端输出:

reveMsg = Hello! I'm Client0; remote port =/127.0.0.1:54233
reveMsg = Hello! I'm Client1; remote port =/127.0.0.1:54233
reveMsg = Hello! I'm Client2; remote port =/127.0.0.1:54233
reveMsg = Hello! I'm Client3; remote port =/127.0.0.1:54233
reveMsg = Hello! I'm Client4; remote port =/127.0.0.1:54233

  

这个情景不具有现实意义,当发送数据较大较快的时候,服务端的TCP连接是无法区分数据怎么分离的

这个设定是buffer足够大,client端发送不够快 如果将buffer设置为2

运输层协议----UDP的更多相关文章

  1. 运输层协议——UDP

    UDP概述: UDP只是做了运输层协议能做的最少工作,仅做了复用/分解,少量的差错检验. UDP是无连接的. UDP优点: 关于何时.发送什么数据的应用层控制更为精细:TCP在拥堵时会遏制发送方的发送 ...

  2. 计算机网络基础笔记 运输层协议UDP/TCP

    目录 UDP 首部结构 主要特点 TCP 首部结构 主要特点 TCP 可靠性实现 停止等待ARQ协议 连续ARQ协议&滑动窗口协议 拥塞控制 TCP 运输连接管理 连接建立:三次握手 连接释放 ...

  3. 运输层协议--TCP及UDP协议

    TCP及UDP协议 按照网络的五层分级结构来看,TCP及UDP位于运输层,故TCP及UDP是运输层协议.TCP协议--传输控制协议UDP协议--用户数据报协议 多路复用及多路分解 图多路复用及多路分解 ...

  4. 运输层2——用户数据报协议UDP

    目录 1. UDP概述 2. UDP首部格式 3. UDP首部检验和计算方法 写在前面:本文章是针对<计算机网络第七版>的学习笔记 运输层1--运输层协议概述 运输层2--用户数据报协议U ...

  5. 运输层协议TCP和UDP

    运输层协议TCP和UDP 一.用户数据报协议 UDP 1.1.UDP 概述 UDP 只在 IP 的数据报服务之上增加了很少一点的功能,即端口的功能和差错检测的功能. 虽然 UDP 用户数据报只能提供不 ...

  6. 运输层协议:TCP和UDP

    运输层简介 运输层的通信实体不再是主机,而是主机中的进程.运输层的通信是一台主机的进程和另一台主机的进程进行数据交换. 运输层作用 运输层向上层的应用层提供通信服务 运输层为进程提供端到端的通信 运输 ...

  7. TCP/IP协议---UDP协议

    UDP是一个简单的面向数据报的运输层协议:进程的每个输出操作都产生一个UDP数据报,并组装成一份待发送的IP数据报.UDP数据报是要依赖IP数据报传送的.UDP协议并不可靠,它不能保证发出去的包会被目 ...

  8. Android程序员必知必会的网络通信传输层协议——UDP和TCP

    1.点评 互联网发展至今已经高度发达,而对于互联网应用(尤其即时通讯技术这一块)的开发者来说,网络编程是基础中的基础,只有更好地理解相关基础知识,对于应用层的开发才能做到游刃有余. 对于Android ...

  9. java 网络通信传输层协议——UDP和TCP

    本文原文由作者“zskingking”发表于:jianshu.com/p/271b1c57bb0b,本次收录有改动. 1.点评 互联网发展至今已经高度发达,而对于互联网应用(尤其即时通讯网专注的即时通 ...

随机推荐

  1. Find发帖水王哥

    Find发帖水王 传说贴吧有一大“水王”,他不但喜欢发帖,还会回复其他ID发的每个帖子.坊间风闻该“水王”发帖数目超过了帖子总数的一半.如果你有一个当前论坛上所有帖子(包括回帖)的列表,其中帖子作者的 ...

  2. Operfire/XMPP

    Operfire/XMPP 关于Openfire.XMPP协议.IM相关知识 基于开源 Openfire 聊天服务器 - 开发聊天记录插件 posted @ 2013-03-29 11:03 hooj ...

  3. 开源免费天气预报接口API以及全国全部地区代码!!(国家气象局提供)

    国家气象局提供的天气预报接口 接口地址: http://www.weather.com.cn/data/sk/101010100.html http://www.weather.com.cn/data ...

  4. java Thread.join()

    thread1.join()方法阻塞调用此方法的线程,直到线程thread1完成,此线程再继续. 通常用于在main()主线程内,等待其它线程完成再结束main()主线程 @Test /** * ou ...

  5. Jquery调用从ashx文件返回的jsonp格式的数据处理实例

    开发环境:vs2010+jquery-1.4.min.js 解决问题:网上代码比较少,好多调试不通,返回数据不用json而用jsonp主要考虑解决跨域问题 开发步骤:打开VS2010,新建一web站点 ...

  6. 【Android】数据库的简单应用——创建数据库

    SQLiteOpenHelper是一个抽象类,要使用它必须写一个类继承它.SQLiteOpenHelper有两个抽象方法onCreate()和onUpgrade(),我们要在类里面重写这两个方法来实现 ...

  7. ci 中使用 pdo 连接 mysql

    ci 版本为 3.0.6 config/database.php 文件内容如下 $active_group = 'default'; $query_builder = TRUE; $db['defau ...

  8. Controller里写自己需要的Action,参数的名字必须和路由设置的参数名一致

    Controller里写自己需要的Action,参数的名字必须和路由设置的参数名一致,如果参数不一致,传过去为null

  9. css3新增加的选择器

    css3新增加的选择器 一.属性选择器: E[attr] 只要有属性名E[attr=value] 属性名=属性值E[attr~=blue] 包含这个blue整个单词就可以E[attr^=c] 以这个字 ...

  10. json 是什么

    怎么学习一个知识? 首先要提出几个问题,目前认为json是个什么,json是谁创造的,为什么而出现的,但是目前仅有很长时间之前别人直接告诉我的,json用来存数据的,对于使用也忘记的差不多了,所以现在 ...