UDP详解

  一,TCP/IP协议栈中,TCP协议和UDP协议的联系和区别?

    联系:

      TCP和UDP是TCP/IP协议栈中传输层的两个协议,它们使用网络层功能把数据包发送到目的地,从而为应用层提供网络服务。

    区别:

      1. TCP是面向连接的传输。UDP是无连接的传输。

      2. TCP保证数据按照发送顺序到达,UDP无法保证。

      4. TCP是可靠性传输,而UDP则是不可靠传输。

      5. UDP因为少了很多控制信息,所以传输速度比TCP速度快。

      6. TCP适合用于传输大量数据,UDP适合用于传输小量数据。

      举例: TCP的server和client之间通信就好比两个人打电话。UDP的server和client之间的通信就像两个人发电报或者发短信。

  二,UDP通讯协议的特点:

      1. 将数据极封装为数据包,面向无连接。

         2. 每个数据包大小限制在64K中

         3.因为无连接,所以不可靠

      4. 因为不需要建立连接,所以速度快

         5.udp 通讯是不分服务端与客户端的,只分发送端与接收端

  三,怎样来编写UDP?

      发送数据步骤:

        1.创建socket服务

        2.创建数据包

        3.将数据封装到数据包中,添加ip和端口以及数据

        4.发送

        5.关闭资源

      接收数据步骤:

        1.创建socket服务,并监听端口

        2.创建数据包,用来接收数据

        3.用socket接收数据到数据包中

        4.从数据包中取出数据

        5.关闭资源

  四,代码实现UDP通信

              1.客户端代码

  1. import java.io.IOException;
  2. import java.net.DatagramPacket;
  3. import java.net.DatagramSocket;
  4. import java.net.InetAddress;
  5. import java.util.Scanner;
  6.  
  7. public class User {
  8. static Scanner sc= new Scanner(System.in);
  9. public static void main(String[] args) throws IOException {
  10. //1.创建客户端套接字
  11. DatagramSocket ds = new DatagramSocket();
  12. //2.创建客户端发送数据包
  13. while(true){
  14. System.out.println("请输入要发送的信息:");
  15. String info = sc.nextLine();
  16. byte []buf =info.getBytes();
  17. DatagramPacket dp = new DatagramPacket(buf, buf.length,
  18. InetAddress.getByName("localhost"), 152);
  19. //3.发送数据包
  20. ds.send(dp);
  21. //4.结束发送循环
  22. if("886".equals(info)){
  23. break;
  24. }
  25. }
  26. //5.关闭套接字
  27. ds.close();
  28. }
  29. }

    2.服务端代码

  1. import java.io.IOException;
  2. import java.net.DatagramPacket;
  3. import java.net.DatagramSocket;
  4. import java.net.InetAddress;
  5.  
  6. public class Server {
  7. public static void main(String[] args) throws IOException {
  8. //1.创建服务端套接字
  9. DatagramSocket ds = new DatagramSocket(152);//注意指定端口
  10. //2.创建接受客户端信息的空数据包
  11. while(true){
  12. byte [] buf =new byte[1024];
  13. DatagramPacket dp = new DatagramPacket(buf, buf.length);
  14. //3.接受数据
  15. ds.receive(dp);
  16. //4.拆分数据
  17. byte[] data = dp.getData();
  18. //5.获取客户端IP和主机名
  19. InetAddress ip = dp.getAddress();
  20. String host = ip.getHostName();
  21. //6.读取数据
  22. String info = new String(buf,0,buf.length);
  23. System.out.println("来自"+host+"的消息是:"+info);
  24. ds.close();
  25. //7.关闭套接字
  26. }
  27. }
  28. }

精品java学习视频

java的IO流技术:链接:https://pan.baidu.com/s/1KWR9JHQ20uy0mx-1CIBwvA  提取码:3dn8 

java网络编程(UDP详解)的更多相关文章

  1. java网络编程(TCP详解)

    网络编程详解-TCP 一,TCP协议的特点              面向连接的协议(有发送端就一定要有接收端)    通过三次连接握手建立连接 通过四次握手断开连接 基于IO流传输数据 传输数据大小 ...

  2. java并发编程 | 锁详解:AQS,Lock,ReentrantLock,ReentrantReadWriteLock

    原文:java并发编程 | 锁详解:AQS,Lock,ReentrantLock,ReentrantReadWriteLock 锁 锁是用来控制多个线程访问共享资源的方式,java中可以使用synch ...

  3. Java网络编程UDP通信原理

    前言 继续今天我们的Java网络编程--TCP和UDP通信 一.TCP和UDP概述 传输层通常以TCP和UDP协议来控制端点与端点的通信   TCP UDP 协议名称 传输控制协议 用户数据包协议 是 ...

  4. java 网络编程 UDP TCP

    网络编程 网络编程主要用于解决计算机与计算机(手机.平板..)之间的数据传输问题. 网络编程: 不需要基于html页面就可以达到数据之间的传输. 比如: feiQ , QQ , 微信....网页编程: ...

  5. java并发编程 | 线程详解

    个人网站:https://chenmingyu.top/concurrent-thread/ 进程与线程 进程:操作系统在运行一个程序的时候就会为其创建一个进程(比如一个java程序),进程是资源分配 ...

  6. JAVA网络编程--UDP通信

    首先网络传输数据需了解例如以下三点 1.找到对方IP 2.数据要发送到对方指定的应用程序上,为了标识这些应用程序,所以给这些网络应用程序用数字进行了标识.为了方便称呼这个数字,叫做port,逻辑por ...

  7. Java网络编程——UDP聊天程序

    UDP简介 UDP协议的全称是用户数据报,在网络中它与TCP协议一样用于处理数据报.在OSI模型中,UDP位于第四层--传输层,处于IP协议额上一层.UDP有不提供数据报分组.组装以及不能对数据报排序 ...

  8. Java网络编程(UDP协议:接收端)

    package WebProgramingDemo; import java.io.IOException; import java.net.DatagramPacket; import java.n ...

  9. Java网络编程(UDP协议:发送端)

    package WebProgramingDemo; import java.io.IOException; import java.net.DatagramPacket; import java.n ...

随机推荐

  1. 牛客多校第四场 J.Hash Function(线段树优化建图+拓扑排序)

    题目传送门:https://www.nowcoder.com/acm/contest/142/J 题意:给一个hash table,求出字典序最小的插入序列,或者判断不合法. 分析: eg.对于序列{ ...

  2. javascript浅拷贝深拷贝理解记录

    javascript的深拷贝和浅拷贝问题几乎是面试必问的问题.好记性不如烂笔头,特此来记录一下自己对深拷贝浅拷贝的理解. 顾名思义,拷贝就是copy复制,在js中可以浅而理解为对一个对象或者数组的复制 ...

  3. Android Ble4.0开发

    最近在做一个蓝牙的项目,是Blu4.0,Android系统支持是4.3版本以上(为此特地卖了个手机,). 当然也参考了不少大牛的的微博,说的都不错,再次特地感谢 http://blog.csdn.ne ...

  4. 数据库中"DDL","DML","DCL"

    sql组成:DDL:数据库模式定义语言,关键字:createDML:数据操纵语言,关键字:Insert.delete.updateDCL:数据库控制语言 ,关键字:grant.removeDQL:数据 ...

  5. Docker学习--Linux基础准备篇

    1.docker命令不需要附带敲sudo的解决办法 由于docker daemon需要绑定到主机的Unix socket而不是普通的TCP端口,而Unix socket的属主为root用户,所以其他用 ...

  6. centos7.2 get pid by process name with python3.6

    centos7.2 get pid by process name with python3.6 #-*- encoding:UTF-8 -*- import os import sys import ...

  7. (转)MySQL详解--锁

    原文:http://blog.csdn.net/xifeijian/article/details/20313977 锁是计算机协调多个进程或线程并发访问某一资源的机制.在数据库中,除传统的计算资源( ...

  8. Sublime Text 3快捷键的使用技巧(python)

    Sublime Text 3非常实用,但是想要用好,一些快捷键不可或缺,所以转了这个快捷键汇总. 先拉出来说几个切身体会最常用, Ctrl+Z 撤销. Ctrl+Y 恢复撤销 Alt+Shift+2  ...

  9. C++中class的类型转换重载

    注:本文测试实例使用的编译器版本为clang-703.0.29. 我们已经习惯了基本数据类型的显式或隐示转换,如: ; float f = (float)a;float c = a; 其实通过oper ...

  10. nginx 超时问题: upstream timed out (110: Connection timed out) while reading response header from upstream

    目录 错误内容 错误原因 错误解决办法 错误内容 我们可以在error.log 里面可以看到 错误内容:upstream timed out (110: Connection timed out) w ...