1.基本概念:

  a.DatagramPacket与DatagramSocket位于java.net包中

  b.DatagramPacket表示存放数据的数据报,DatagramSocket表示接受或发送数据报的套接字

  c.由这两个类所有构成的网络链接是基于UDP协议,是一种不可靠的协议。

  之所以不可靠是因为发送方不负责数据是否发送成功,接收方收到数据时也不会   向发送方反馈成功消息,容易导致信息的丢失。

  但是这种协议却是快捷的,比如CS(半条命)游戏就是基于UDP协议,否则我们估计   要玩一次游戏后就会把机子砸了,所以我们可以看到游戏有时会失帧。

  2.使用方法:

  要建立基于UDP协议的链接,我们应该先建立套接字<DatagramSocket>(即发送站或接收站),之后通过套接字发送或接受数据<DatagramPacket>。

  我们先了解一下DatagramSocket和DatagramPacket类

  DatagramSocket类:

  构造方法:

  DatagramSocket():

  表示创建一个默认的套接字,并绑定到本地地址和一个随机的端口号

  DatagramSocket(int port):

  与上面不同的是,绑定到特定端口号,其它不变

  DatagramSocket(int port, InetAddress iad):

  表示创建一个套接字,绑定到特定的端口号及指定地址

  DatagramSocket(SocketAddress sad);

  表示创建一个套接字,绑定到特定的套接字地址

  小提示:所谓的本地地址我们可以这样来理解,我们通过“控制面板-本地连接-支持”中可以看到一个IP地址,这就是本地的IP地址,也暂且理解为本地地址。

  基本方法:

  close():

  关闭套接字

  recevie(DatagramPacket dp):

  接受数据报

  send(DatagramPacket dp):

 发送数据报

  这里触及了数据报,下面介绍数据报:

  DatagramPacket类:

  构造方法:(只列出主要的)

  接受类型:

  DatagramPacket(byte[] buf, int length):

  用来接受长度为length的buf数据(即数据存于字节数组buf中)

  发送类型:

  DatagramPacket(byte[] buf, int length, InetAddress address, int port);

  将length长的buf数据发送到指定的地址的端口号处

  DatagramPacket(byte[] buf, int length, SocketAddress address);

   将length长的buf数据发送到指定的套接字地址处

  有上面可知,我们发送数据时构造的数据报应该是发送类型的,而接受数据报时应该是接受类型的    

  开始书写代码

  代码意图:

  1.一个接收方,一个发送方

  2.当接收方收到发送方发送的消息后,打印发送的消息及发送方的地址和端口号,之后向发送反馈一条信息“接受方:我收到了!”

  3.发送方打印出接收方反馈的消息

  详细思路见代码:

import java.net.DatagramPacket;  

import java.net.DatagramSocket;  

import java.net.InetAddress;  

public class Sender {  

public static void main(String[] args) {  

try {  

// 创建发送方的套接字,IP默认为本地,端口号随机  

            DatagramSocket sendSocket = new DatagramSocket();  

// 确定要发送的消息:  

            String mes = "你好!接收方!";  

// 由于数据报的数据是以字符数组传的形式存储的,所以传转数据  

byte[] buf = mes.getBytes();  

// 确定发送方的IP地址及端口号,地址为本地机器地址  

int port = 8888;  

            InetAddress ip = InetAddress.getLocalHost();  

// 创建发送类型的数据报:  

            DatagramPacket sendPacket = new DatagramPacket(buf, buf.length, ip,  

                    port);  

// 通过套接字发送数据:  

            sendSocket.send(sendPacket);  

// 确定接受反馈数据的缓冲存储器,即存储数据的字节数组  

byte[] getBuf = new byte[1024];  

// 创建接受类型的数据报  

            DatagramPacket getPacket = new DatagramPacket(getBuf, getBuf.length);  

// 通过套接字接受数据  

            sendSocket.receive(getPacket);  

// 解析反馈的消息,并打印  

            String backMes = new String(getBuf, 0, getPacket.getLength());  

            System.out.println("接受方返回的消息:" + backMes);  

// 关闭套接字  

            sendSocket.close();  

        } catch (Exception e) {  

            e.printStackTrace();  

        }  

    }  

}  
import java.net.DatagramPacket;  

import java.net.DatagramSocket;  

import java.net.InetAddress;  

import java.net.SocketAddress;  

public class Receive {  

public static void main(String[] args) {  

try {  

// 确定接受方的IP和端口号,IP地址为本地机器地址  

            InetAddress ip = InetAddress.getLocalHost();  

int port = 8888;  

// 创建接收方的套接字,并制定端口号和IP地址  

            DatagramSocket getSocket = new DatagramSocket(port, ip);  

// 确定数据报接受的数据的数组大小  

byte[] buf = new byte[1024];  

// 创建接受类型的数据报,数据将存储在buf中  

            DatagramPacket getPacket = new DatagramPacket(buf, buf.length);  

// 通过套接字接收数据  

            getSocket.receive(getPacket);  

// 解析发送方传递的消息,并打印  

            String getMes = new String(buf, 0, getPacket.getLength());  

            System.out.println("对方发送的消息:" + getMes);  

// 通过数据报得到发送方的IP和端口号,并打印  

            InetAddress sendIP = getPacket.getAddress();  

int sendPort = getPacket.getPort();  

            System.out.println("对方的IP地址是:" + sendIP.getHostAddress());  

            System.out.println("对方的端口号是:" + sendPort);  

// 通过数据报得到发送方的套接字地址  

            SocketAddress sendAddress = getPacket.getSocketAddress();  

// 确定要反馈发送方的消息内容,并转换为字节数组  

            String feedback = "接收方说:我收到了!";  

byte[] backBuf = feedback.getBytes();  

// 创建发送类型的数据报  

            DatagramPacket sendPacket = new DatagramPacket(backBuf,  

                    backBuf.length, sendAddress);  

// 通过套接字发送数据  

            getSocket.send(sendPacket);  

// 关闭套接字  

            getSocket.close();  

        } catch (Exception e) {  

            e.printStackTrace();  

        }  

    }  

}  

测试已通过

  先启动接收方,然后启动发送方即可

原文地址:http://blog.csdn.net/pengchua/article/details/4398972

Java中的DatagramPacket与DatagramSocket的初步(转)的更多相关文章

  1. 在Java中实现UDP协议编程(DatagramSocket/DatagramPacket)

    1.什么是UDP协议? UDP( User Datagram Protocol )协议是用户数据报,在网络中它与TCP协议一样用于处理数据包.在OSI模型中,在第四层——传输层,处于IP协议的上一层. ...

  2. 初步探究java中程序退出、GC垃圾回收时,socket tcp连接的行为

    初步探究java中程序退出.GC垃圾回收时,socket tcp连接的行为 今天在项目开发中需要用到socket tcp连接相关(作为tcp客户端),在思考中发觉需要理清socket主动.被动关闭时发 ...

  3. Redis学习记录之Java中的初步使用

    1.关于Redis redis下载地址:<span style="font-family: Arial, Helvetica, sans-serif;">http:// ...

  4. Java中方法的定义与使用,以及对数组的初步了解。

    方法 方法的含义 定义: 方法就是用来完成解决某件事情或实现某个功能的办法. 方法实现的过程中,会包含很多条语句用于完成某些有意义的功能——通常是处理文本,控制输入或计算数值. 我们可以通过在程序代码 ...

  5. Java中循环体的初步了解以及另一种随机数的获取方法

    Math中的相关操作 随机数 Java中除了可以直接导入Random类,获取随机数,还可以通过本身自带的Math方法去获取随机数.Math.random()可以产生随机小数,区间范围为[0.0,1.0 ...

  6. Java中的网络编程

    ​ Java中的网路编程主要是Java的Socket编程,属于JavaEE中的高级的部分,以下内容是对java网路编程的一个小结,代码都是经过编译调试的 C/S程序应用:客户/服务器模式,如QQ客户端 ...

  7. Java中的TCP/UDP网络通信编程

    127.0.0.1是回路地址,用于测试,相当于localhost本机地址,没有网卡,不设DNS都可以访问. 端口地址在0~65535之间,其中0~1023之间的端口是用于一些知名的网络服务和应用,用户 ...

  8. Java 中UDP原理机制及实现方式介绍(建议阅读者阅读前了解下Java的基础知识,一方便理解)

    1.基本概念介绍: 首先得简单介绍下UDP. UDP( User Datagram Protocol )协议是用户数据报,在网络中它与TCP协议一样用于处理数据包.在OSI模型中,在第四层——传输层, ...

  9. Java中的UDP应用

    我在<JavaSE项目之聊天室>中通过遵守TCP协议的ServerSocket与Socket实现了聊天室的群聊窗口.同时,在介绍OSI与TCP/IP参考模型时,也曾提及TCP与UDP(全称 ...

随机推荐

  1. C#获取相对路径的方法

    这八种C#获取相对路径的方法,包括获取和设置当前目录的完全限定路径.获取启动了应用程序的可执行文件的路径,不包括可执行文件的名称等等内容. C#获取相对路径1. 获取和设置当前目录的完全限定路径.   ...

  2. 网站开发中必备的8个 jQuery 效果【附源码】

    jQuery 作为最优秀 JavaScript 库之一,改变了很多人编写 JavaScript 的方式.它简化了 HTML 文档遍历,事件处理,动画和 Ajax 交互,而且有成千上万的成熟 jQuer ...

  3. MongoDB replicaSet

    MongoDB 的replication机制除了最普通的Master/Slave模式之外,更强大的就是其支持自动故障转移的Replica Sets模式了.相对于其问题多多的auto-sharding机 ...

  4. PHP FTP操作类( 上传、拷贝、移动、删除文件/创建目录 )

    /** * 作用:FTP操作类( 拷贝.移动.删除文件/创建目录 ) * 时间:2006/5/9 * 作者:欣然随风 * QQ:276624915 */ class class_ftp { publi ...

  5. Masonry使用案列详解

    案例一: 要求:无论在什么尺寸的设备上(包括横竖屏切换),红色view都居中显示.

  6. bzoj3594: [Scoi2014]方伯伯的玉米田

    dp新优化姿势... 首先,当我们拔高时,一定右端点是n最优.因为如果右端点是r,相当于降低了r之后玉米的高度.显然n更优. 那么可以dp.dp[i][j]表示前i个拔高j次的LIS.dp[i][j] ...

  7. JAVA中StringBuffer类常用方法详解

    String是不变类,用String修改字符串会新建一个String对象,如果频繁的修改,将会产生很多的String对象,开销很大.因此java提供了一个StringBuffer类,这个类在修改字符串 ...

  8. flask剖析

    1.为何只要通过import request,就能拿到对应的request呢?怎么解决区分请求,区分线程的问题? 简而言之,就是通过拿栈顶对象就表示是当前活动的对象 但对于多线程,由于栈的数据结构是 ...

  9. 在ubunut下使用pycharm和eclipse进行python远程调试

    我比较喜欢Pycharm,因为这个是JetBrains公司出的python IDE工具,该公司下的java IDE工具--IDEA,无论从界面还是操作上都甩eclipse几条街,但项目组里有些人使用e ...

  10. JavaScript 时间特效 显示当前时间

    <!DOCTYPE html PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN" "http://www.w3.org/ ...