java udp tcp协议_【java】TCP和UDP传输协议
TCP协议和UDP协议的比较
TCP的全称是Transmission Control Protocol (传输控制协议)
传输控制协议,是一种面向连接的协议,类似打电话
在通信的整个过程中保持连接
保证了数据传递的可靠性和有序性
是一种全双工的字节流通信方式
服务器压力比较大,资源消耗比较快,发送数据效率比较低
UDP是User Datagram Protocol(用户数据报协议)
用户数据报协议,是一种非面向连接的协议,类似写信
在通信的整个过程中不需要保持连接
不保证数据传输的可靠性和有序性
是一种双全工的数据报通信方式
服务器压力比较小,资源比较低,发送效率比较高
基于TCP的网络编程模型
服务器:
创建ServerSocket的对象并且提供端口号, public ServerSocket(int port)
等待客户端的请求连接,使用accept()方法, public Socket accept()
连接成功后,使用Socket得到输入流和输入流,进行通信
关闭相关资源
客户端:
创建Socket类型的对象,并且提供IP地址和端口号, public Socket(String host, int port)
使用Socket构造输入流和输出流进行通信
关闭相关资源
下面这个例子
1 /*
2 * 在提供端口号的时候应该注意:最好定义在1024~49151。3 */
4 public classTestServerString {5
6 public static voidmain(String[] args) {7 try{8 //1.创建ServerSocket类型的对象,并提供端口号
9 ServerSocket ss = new ServerSocket(8888);10 //2.等待客户端的连接请求,使用accept()方法,保持阻塞状态
11 while(true){12 System.out.println("等待客户端的连接请求...");13 Socket s =ss.accept();14 newServerThread(s).start();15 System.out.println("客户端连接成功!");16 }17
18 }catch(Exception e){19 e.printStackTrace();20 }21
22 }23
24 }
TestServerString类
在TestServerString类中采用循环相应多个客户端的连接,
1 public class ServerThread extendsThread{2
3 privateSocket s;4
5 publicServerThread(Socket s){6 this.s=s;7 }8
9 @Override10 public voidrun(){11 try{12 BufferedReader br = newBufferedReader(13 newInputStreamReader(s.getInputStream()));14 PrintStream ps = newPrintStream(s.getOutputStream());15 //编程实现服务器可以不断地客户端进行通信
16 while(true){17 //服务器接收客户端发来的消息并打印
18 String str =br.readLine();19 //当客户端发来"bye"时,结束循环
20 if("bye".equalsIgnoreCase(str)) break;21 System.out.println(s.getLocalAddress()+":"+str);22 //向客户端回发消息“I received!”
23 ps.println("server received!");24 }25 //4.关闭相关的套接字
26 ps.close();27 br.close();28 s.close();29 }catch(Exception e){30 e.printStackTrace();31 }32 }33 }
ServerThread
在输入流和输出流中采用循环可客户端传输信息
1 public classTestClientString {2
3 public static voidmain(String[] args) {4
5 try{6 //1.创建Socket类型的对象,并指定IP地址和端口号
7 Socket s = new Socket("127.0.0.1", 8888);8 //2.使用输入输出流进行通信
9 BufferedReader br = newBufferedReader(10 newInputStreamReader(System.in));11 PrintStream ps = newPrintStream(s.getOutputStream());12 BufferedReader br2 = newBufferedReader(13 newInputStreamReader(s.getInputStream()));14 //编程实现客户端不断地和服务器进行通信
15 while(true){16 //提示用户输入要发送的内容
17 System.out.println("请输入要发送的内容:");18 String msg =br.readLine();19 ps.println(msg);20 //当客户端发送"bye"时,结束循环
21 if("bye".equalsIgnoreCase(msg)){22 break;23 };24 //等待接收服务器的回复,并打印回复的结果
25 String str2 =br2.readLine();26 System.out.println("服务器发来的消息是:" +str2);27 }28 //3.关闭Socket对象
29 br2.close();30 br.close();31 ps.close();32 s.close();33 }catch(Exception e){34 e.printStackTrace();35 }36
37 }38
39 }
TestClientString
在客户端中采用循环,可以让客户端与服务器建立一次连接,实现多次通信
基于UDP的网络编程模型
发送方:
创建DatagramSocket类型的对象,不需要提供任何信息, public DatagramSocket()
创建DatagramPacket类型的对象,指定发送的内容、IP地址、端口号, public DatagramPacket(byte[] buf, int length, InetAddress address, int port)
发送数据,使用send()方法, public void send(DatagramPacket p)
关闭相关的资源
接收方:
创建DatagramSocket类型的对象,并且指定端口, public DatagramSocket(int port)
创建DatagramPacket类型的对象,用于接收发来的数据, public DatagramPacket(byte[] buf, int length)
接收数据,使用receive()方法, public void receive(DatagramPacket p)
关闭相关资源
例:
发送方:
1 public classUDPSender {2
3 public static voidmain(String[] args) {4 try{5 /*
6 * create DatagramSocket instance7 */
8 DatagramSocket ds=newDatagramSocket();9 //create DatagramPackage instance and specify the content to send ,ip address,port
10 InetAddress ia=InetAddress.getLocalHost();11 System.out.println(ia.toString());12 String str="吴兴国";13 byte[] data=str.getBytes();14 DatagramPacket dp=new DatagramPacket(data,data.length,ia,8888);15 //send data use send()
16 ds.send(dp);17 //create DatagramPacket instance for receive
18 byte []b2=new byte[1024];19 DatagramPacket dp2=newDatagramPacket(b2,b2.length);20 ds.receive(dp2);21 System.out.println("result:"+newString(data));22 //close resorce
23 ds.close();24 }catch(IOException e){25 e.printStackTrace();26 }27 }28
29 }
UDPSender
接收方:
1 public classUDPReceiver {2
3 public static voidmain(String[] args) {4 try{5 /*
6 * create DatagramSocket instance,and support port7 */
8 DatagramSocket ds=new DatagramSocket(8888);9 /*
10 * create DatagramPackage instance for receive data11 */
12 byte []data=new byte[1024];13 DatagramPacket dp=newDatagramPacket(data,data.length);14 /*
15 * receive source16 */
17 ds.receive(dp);18 System.out.println("contents are:"+new String(data,0,dp.getLength()));19 /*
20 * send data21 */
22 String str="I received!";23 byte[] b2=str.getBytes();24 DatagramPacket dp2=
25 newDatagramPacket(b2,b2.length,dp.getAddress(),dp.getPort());26 ds.send(dp2);27 System.out.println("发送成功,ip:"+dp.getAddress());28
29 /*
30 * close resource31 */
32 }catch(SocketException e){33 e.printStackTrace();34 }catch(IOException e){35 e.printStackTrace();36 }37 }38
39 }
UDPReceiver
网络编程中定义端口应注意
互联网中的协议被分为三种,
众所周知(Well Known Ports)端口:编号0~1023,通常由操作系统分配,用于标识一些众所周知的服务。众所周知的端口编号通常又IANA统一分配
注册(Registered Ports)端口:编号1024~49151,可以动态的分配给不同的网络应用进程。
私有(Private Ports)端口:编号49159~65535,一般情况下,这些端口不分配网络应用进程。
参考文章:
java udp tcp协议_【java】TCP和UDP传输协议相关推荐
- User Datagram Protocol:Internet 协议集支持一个无连接的传输协议
Internet 协议集支持一个无连接的传输协议,该协议称为用户数据报协议(UDP,User Datagram Protocol).UDP 为应用程序提供了一种无需建立连接就可以发送封装的 IP 数据 ...
- gns3中两个路由器分别连接主机然后分析ip数据转发报文arp协议_关于TCP/IP,必知必会的十个问题!...
本文整理了一些TCP/IP协议簇中需要必知必会的十大问题,既是面试高频问题,又是程序员必备基础素养. TCP/IP十个问题 TCP/IP十个问题 一.TCP/IP模型 TCP/IP协议模型(Trans ...
- tcp ip协议_网络通信-TCP/IP协议族简述
导读:计算机与网络设备要相互通信需要遵守同样的规则.例如,如何找到通信目标.该使用哪种语言通信.怎么结束通信等规则.不同的硬件.操作系统之间的通信都需要遵循同一种规则,这种规则也称为是协议.下面本文主 ...
- 为什么tcp不采用停等协议_为什么 TCP 协议有粘包问题
来自公众号:真没什么逻辑 链接:https://draveness.me/whys-the-design-tcp-message-frame/ 为什么这么设计(Why's THE Design)是一系 ...
- java 链接sqlserver2008驱动_|java连接sqlserver2008驱动包下载免费版 - 欧普软件下载
java连接sqlserver2008驱动包是java连接数据库的驱动安装程序,当您连接数据库时提示驱动不匹配的问题就需要来本站下载java连接sqlserver2008驱动包,安装一下就可使用了.具 ...
- 大白话了解TCP协议:了解TCP?先别急,来看看TCP的前世——“最简单的”可靠传输协议:停止等待协议
TCP是可靠传输协议的衍生.拓展 先了解可靠传输协议的基本概念就可以非常轻松得了解TCP协议了! 这是个有安全感的协议类型~ 在漫长的线路中,这些数据要经过路由器.网线,甚至还有风风雨雨--数据就很容 ...
- java 基础面试 英文_[Java面试] 面试java基础总结大全
原标题:[Java面试] 面试java基础总结大全 基础知识: 1.JVM.JRE和JDK的区别: JVM(Java Virtual Machine):java虚拟机,用于保证java的跨平台的特性. ...
- tcp拥塞控制_网络TCP的拥塞控制算法简介
作为网络中使用最广泛的传输协议,TCP的拥塞控制机制是学术界和工业界关注的焦点问题之.然而,目前广泛使用的TCP传输协议的拥塞控制算法仍然使用相对固定的窗口调节策略,无法根据动态变化的场景自适应地调整 ...
- java 内存泄露 书籍_[Java教程]一次艰难的内存泄露排查,BeanUtils 的锅
[Java教程]一次艰难的内存泄露排查,BeanUtils 的锅 0 2020-10-29 18:24:42 现象 通过jstat -gcutil pid 5000 ,发现fgc次数很多而且频繁,此时 ...
- java privatekey输出字符串_[Java教程]根据字符串(String)生成公钥(PublicKey)和私钥(PrivateKey)对象_星空网...
根据字符串(String)生成公钥(PublicKey)和私钥(PrivateKey)对象 2012-05-29 0 1.字符串生成公钥对象 PublicKey /** * 实例化公钥 * * @re ...
最新文章
- 关于wpf窗体中Allowtransparent和WindowsFormsHost的纠纷
- C语言函数sscanf()的用法
- OpenGL3.x,4.x中使用FreeImage显示图片的BUG-黑色,或颜色分量顺序错乱
- gcc support java_由于CC寻找不存在的gcc版本,自制软件无法安装公式
- 【XSY2519】神经元 prufer序列 DP
- 苹果悬赏100万美元找漏洞 辞职的理由找到了!
- 问题 L: 一年中的第几天
- mnist数据集无法下载
- 穿越计算机的迷雾--读书笔记五
- 初识app之产品需求分析文档设计
- iOS实现炫酷悬停交互视图
- 移动APP测试经验总结
- isis学不到looback口的路由_无线路由器怎么设置无线桥接 无线路由器设置无线桥接步骤【教程】...
- 如何获取网站的ico图标
- Java学习笔记---Lambda表达式及Stream流Api
- Scratch基础教学之孙悟空的吹毛变猴
- ArcGIS server如何将自己的小地图叠加到Google maps或者Virtual Earth上[转]
- 【山大会议】多人视频通话 WebRTC 工具类搭建
- 创建TimesTen 数据库
- Css3学习日志 --css层叠样式表
热门文章
- Rocksdb 的优秀代码(一) -- 工业级分桶算法实现分位数p50,p99,p9999
- ceph bluestore源码分析:C++ 获取线程id
- [dp] Jzoj P5804 简单的序列
- sliva数据库简介--转载
- Matlab并行编程方法1
- python三层架构
- hdu 2028 Lowest Common Multiple Plus
- 有界阻塞队列ArrayBlockingQueue和无界阻塞队列LinkedBlockingQueue
- 最新的全球编程语言,操作系统,web服务器等使用率分析报告
- 深入理解PHP原理之变量作用域