Java:网络编程之UDP的使用

简介:
java.net 
类 DatagramSocket 此类表示用来发送和接收数据报包的套接字,数据报套接字是包投递服务的发送或接收点。
java.net 
类 DatagramPacket 此类表示数据报包,数据报包用来实现无连接包投递服务。
 
 <1> void send(DatagramPacket p) 
          从此套接字发送数据报包。
 DatagramPacket(byte[] buf, int length, InetAddress address, int port) 
          构造数据报包,用来将长度为 length 的包发送到指定主机上的指定端口号。
 
 <2>void receive(DatagramPacket p) 
          从此套接字接收数据报包。  
 DatagramPacket(byte[] buf, int length) 
          构造 DatagramPacket,用来接收长度为 length 的数据包。  
 
需求:通过UDP传输方式,将一段文字数据发送出去。
思路:1.建立udpscoket服务
         2.提供数据,并将数据封装到数据包中
         3.通过scoket服务的功能将数据发出去
         4.关闭资源
//例子如下:
复制代码
import java.net.*;

//发送数据
class UdpSend
{
    public static void main(String[] args)throws Exception
    {
        //1,建立udp服务,通过DatagramScoket,建立端点
        DatagramSocket ds = new DatagramSocket(10000);//可以指定发送端口,例如10000,也可以不用指定,让系统随机默认分配
        
        //2,确定数据,并封装成数据包.DatagramPacket(byte[] buf, int length, InetAddress address, int port)
        byte[] buf = "udp is coming".getBytes();//直接指定信息数据

        DatagramPacket dp = new DatagramPacket(buf,buf.length,InetAddress.getByName("192.168.1.105"),8888);
            
        //3,通过scoket服务的send方法发送数据,
        ds.send(dp);
        
        //4,关闭资源
        ds.close();         
    }
}
复制代码

 

需求:定义一个应用程序,用于接收udp协议传输的数据并处理
思路:1.定义udpscoket服务,通常会监听一个端口,其实就是给这个接受网络应用程序定义一个数字标识。方便于明确哪些数据过来该应用程序可以处理。
         2.定义一个数据包,因为要存储要接收的数据,因为数据包对象中有更多功能可以提取字节数据中的不同数据信息
         3.通过scoket服务的receive方法将接收到的字节数据存储到定义好的数据包中
         4.通过数据包对象的特有功能,将不同的数据取出,打印在控制台上。
         5.关闭资源
//例子如下:
复制代码
//接收数据
class UdpReceive
{
    public static void main(String[] args)throws Exception
    {
        //1,建立udp服务,通过DatagramScoket,建立端点
        DatagramSocket ds = new DatagramSocket(8888);//必须指定接收端应用程序的端口,用来匹配发送端数据包来的端口号
        while(true)
        {
            //2,创建一个字节数据包用于存储接收过来的字节数据
            byte[] buf = new byte[1024];
            DatagramPacket dp = new DatagramPacket(buf,buf.length);
            
            //3,通过scoket服务的receive方法接收数据,
            ds.receive(dp);//阻塞式方法
            
            //4,将字节数据转换为字符串并输出
            String message = new String(dp.getData(),0,dp.getLength());
            String IP = dp.getAddress().getHostAddress();
            int port = dp.getPort();
            System.out.println("IP:"+IP+"::"+"port:"+port);        
            System.out.println("message:"+message);    
        }
       
        //5,关闭资源
        //ds.close();    
    }
}
复制代码

 

 
程序猿神奇的手,每时每刻,这双手都在改变着世界的交互方式!

本文转自当天真遇到现实博客园博客,原文链接:http://www.cnblogs.com/XYQ-208910/p/4918884.html ,如需转载请自行联系原作者
相关文章
|
5天前
|
Java
java网络编程 UDP通信协议实现局域网内文件的发送和接收
java网络编程 UDP通信协议实现局域网内文件的发送和接收
java网络编程 UDP通信协议实现局域网内文件的发送和接收
|
5天前
|
网络协议 视频直播 SDN
计算机网络:TCP协议的三次握手和四次挥手与UDP协议区别.
计算机网络:TCP协议的三次握手和四次挥手与UDP协议区别.
16 1
|
11天前
|
网络协议 Java 关系型数据库
16 Java网络编程(计算机网络+网络模型OSI/TCP/IP+通信协议等)
16 Java网络编程(计算机网络+网络模型OSI/TCP/IP+通信协议等)
41 2
|
18天前
|
Java 应用服务中间件 Linux
(九)Java网络编程无冕之王-这回把大名鼎鼎的Netty框架一网打尽!
现如今的开发环境中,分布式/微服务架构大行其道,而分布式/微服务的根基在于网络编程,而Netty恰恰是Java网络编程领域的无冕之王。Netty这个框架相信大家定然听说过,其在Java网络编程中的地位,好比JavaEE中的Spring。
|
19天前
|
安全 Java Linux
(七)Java网络编程-IO模型篇之从BIO、NIO、AIO到内核select、epoll剖析!
IO(Input/Output)方面的基本知识,相信大家都不陌生,毕竟这也是在学习编程基础时就已经接触过的内容,但最初的IO教学大多数是停留在最基本的BIO,而并未对于NIO、AIO、多路复用等的高级内容进行详细讲述,但这些却是大部分高性能技术的底层核心,因此本文则准备围绕着IO知识进行展开。
|
19天前
|
存储 Java Unix
(八)Java网络编程之IO模型篇-内核Select、Poll、Epoll多路复用函数源码深度历险!
select/poll、epoll这些词汇相信诸位都不陌生,因为在Redis/Nginx/Netty等一些高性能技术栈的底层原理中,大家应该都见过它们的身影,接下来重点讲解这块内容。
|
1月前
|
Java 大数据
如何在Java中进行网络编程:Socket与NIO
如何在Java中进行网络编程:Socket与NIO
|
3月前
|
监控 Java 开发者
深入理解 Java 网络编程和 NIO
【4月更文挑战第19天】Java网络编程基于Socket,但NIO(非阻塞I/O)提升了效率和性能。NIO特点是非阻塞模式、选择器机制和缓冲区,适合高并发场景。使用NIO涉及通道、选择器和事件处理,优点是高并发、资源利用率和可扩展性,但复杂度、错误处理和性能调优是挑战。开发者应根据需求选择是否使用NIO,并深入理解其原理。
40 1
|
JSON 前端开发 安全
Java网络编程IO模型 --- BIO、NIO、AIO详解
Java网络编程IO模型 --- BIO、NIO、AIO详解
332 0
Java网络编程IO模型 --- BIO、NIO、AIO详解
|
JSON 安全 JavaScript
Java网络编程IO模型 --- BIO、NIO、AIO详解
一文教你搞懂Java网络编程 BIO、NIO、AIO
395 0
Java网络编程IO模型 --- BIO、NIO、AIO详解