java网络编程之UDP通讯
详细介绍了java中的网络通信机制,尤其是UDP协议,通过对UDP的基本使用进行举例说明如何使用UDP进行数据的发送接收,并举了两个小demo说明UDP的使用注意事项。
UDP协议原理图解:

UDP协议:需要借助于InetAddress来获取设备的IP地址,以及姓名
import java.io.IOException;
import java.net.Inet4Address;
import java.net.InetAddress;
import java.net.UnknownHostException; public class InetAddressDemo {
public static void main(String[] args) throws IOException {
// InetAddress address = InetAddress.getByName("10.129.123.23");
InetAddress address = InetAddress.getByName("ooo-PC");
// InetAddress address = InetAddress.getByName("lpp-PC"); // 获取该ip地址对象的IP地址和主机名
String name = address.getHostName();
String ip = address.getHostAddress(); System.out.println(name);
System.out.println(ip);
}
}
/*
* 网络通讯三要素:
* 1.IP地址:InetAddress 网络中设备的标识,不易记忆,可用主机名;
* 2.端口号:用于标识进程的逻辑地址,不同进程的标识传输协议通讯的规则;用于标识进程的逻辑地址,不同进程的标识,
* 有效端口:0~65535,其中0~1024系统使用或保留端口。
* 3.常见协议:TCP,UDP。
*/ /*
* UDP协议
* 将数据源和目的封装成数据包中,不需要建立连接;
* 每个数据报的大小在限制在64k;
* 因无连接,是不可靠协议;
* 不需要建立连接,速度快
*/ /*
* Socket套接字:
* 网络上具有唯一标识的IP地址和端口号组合在一起才能构成唯一能识别的 标识符套接字。
* Socket原理机制:通信的两端都有Socket。
* 网络通信其实就是Socket间的通信。
* 数据在两个Socket间通过IO传输。
*/ //第一部分代码是接收端,一般是先开接收端的代码,再开发送端
//接收端代码的创建步骤如下:
/*
* UDP协议接收数据:
* 1.创建接收端socket对象
* 2.创建一个数据包(接收数据的容器)
* 3.调用socket的对象的接收方法接收数据
* 4.解析数据,并显示在控制台
* 5.释放资源
*/ import java.io.IOException;
import java.net.DatagramPacket;
import java.net.DatagramSocket;
import java.net.InetAddress;
import java.net.SocketException; /*
* 对于里面创建对象的部分进行优化直接链式编程
* java.net.BindException: Address already in use: Cannot bind
* 该端口已经被使用了,有可能是第二次调用或者第一次调用的时候该端口被其它程序使用。
*/
public class ReceiveDemo {
public static void main(String[] args) throws IOException {
// 创建接收端数socket对象,指定端口。
DatagramSocket ds = new DatagramSocket(10086);
// 接收数据
byte[] buf = new byte[1024];
// int length = buf.length;
DatagramPacket dp = new DatagramPacket(buf, buf.length);
ds.receive(dp); // 将接受的数据放进dp数据报包中
// 解析数据,获取IP地址以及数据报包中的内容
// InetAddress address = dp.getAddress();
// String ip = address.getHostAddress();
// byte[] bys = dp.getData();
// int len = dp.getLength(); // 数据报包的实际长度 String ip = dp.getAddress().getHostAddress();
String s = new String(dp.getData(), 0, dp.getLength()); System.out.println(ip + ":--" + s); // 释放资源
ds.close(); }
} //----------------------------------------
//下面是发送端的代码,与上面分开在两个类 import java.io.IOException;
import java.net.DatagramPacket;
import java.net.DatagramSocket;
import java.net.InetAddress;
import java.net.SocketException; public class SendDemo {
public static void main(String[] args) throws IOException {
// 发送端socket对象
DatagramSocket ds = new DatagramSocket(); // 数据打包
byte[] bys = "java".getBytes();
// int len = bys.length;
// InetAddress address = InetAddress.getByName("lpp-PC");
// int port = 10086; DatagramPacket dp = new DatagramPacket(bys, bys.length,
InetAddress.getByName("lpp-PC"), 10086); // 发送数据
ds.send(dp); // 释放资源
ds.close();
}
}
/*
* 多线程实现在一个代码里面姐发送又接受数据
* 在发送端从键盘录入数据,一直读到886结束数据的录入发送,键盘录入一句就接受一句,接收端一直开着等着数据的发送。
*/ //首先是main方法 import java.io.IOException;
import java.net.DatagramSocket;
import java.net.SocketException; /*
* 通过多线程
*/
public class chatRoomDemo {
public static void main(String[] args) throws IOException {
// 接收端,发送端socket
DatagramSocket dsSend = new DatagramSocket();
DatagramSocket dsReceive = new DatagramSocket(10086); SendThread st = new SendThread(dsSend);
ReceiveThread rt = new ReceiveThread(dsReceive); // 线程开启
Thread sendThread = new Thread(st);
Thread receiverThread = new Thread(rt); sendThread.start();
receiverThread.start();
}
} //--------------------------------------------
//接收端线程的创建
import java.io.IOException;
import java.net.DatagramPacket;
import java.net.DatagramSocket; public class ReceiveThread implements Runnable {
private DatagramSocket ds; public ReceiveThread(DatagramSocket ds) {
// 通过构造方法进行初始化
this.ds = ds;
} @Override
public void run() {
// TODO Auto-generated method stub
while (true) {
try {
byte[] buf = new byte[1024];
DatagramPacket dp = new DatagramPacket(buf, buf.length);
ds.receive(dp); String ip = dp.getAddress().getHostAddress(); String s = new String(dp.getData(), 0, dp.getLength()); System.out.println(ip + "--->" + s);
} catch (IOException e) {
e.printStackTrace();
}
}
}
} //---------------------------------------
//发送端线程的创建 import java.io.BufferedReader;
import java.io.IOException;
import java.io.InputStream;
import java.io.InputStreamReader;
import java.net.DatagramPacket;
import java.net.DatagramSocket;
import java.net.InetAddress; public class SendThread implements Runnable {
private DatagramSocket ds; public SendThread(DatagramSocket ds) {
this.ds = ds;
} @Override
public void run() {
// TODO Auto-generated method stub
try {
BufferedReader br = new BufferedReader(new InputStreamReader(
System.in));
String line = null;
while ((line = br.readLine()) != null) {
if ("886".equals(line)) {
break;
}
byte[] buf = line.getBytes();
DatagramPacket dp = new DatagramPacket(buf, buf.length,
InetAddress.getByName("lpp-PC"), 10086); ds.send(dp);
}
} catch (IOException e) {
e.printStackTrace();
}
// //释放资源
// ds.close();
} }
java网络编程之UDP通讯的更多相关文章
- Java网络编程之UDP
Java网络编程之UDP 一.C/S架构中UDP网络通信流程 ①创建DatagramSocket与DatagramPacket对象 ②建立发送端,接收端 ③建立数据包 ④调用Socket的发送.接收方 ...
- java网络编程之TCP通讯
java中的网络编程之TCP协议的详细介绍,以及如何使用,同时我在下面举2例说明如何搭配IO流进行操作, /* *TCP *建立连接,形成传输数据的通道: *在连接中进行大数据量传输: *通过三次握手 ...
- java 网络编程之UDP通信和简单的群聊程序
*/ .hljs { display: block; overflow-x: auto; padding: 0.5em; color: #333; background: #f8f8f8; } .hl ...
- java网络编程之UDP实例
package Socket; import java.net.DatagramPacket; import java.net.InetAddress; public class Dgram { pu ...
- Java网络编程之TCP、UDP
Java网络编程之TCP.UDP 2014-11-25 15:23 513人阅读 评论(0) 收藏 举报 分类: java基础及多线程(28) 版权声明:本文为博主原创文章,未经博主允许不得转载. ...
- 网络编程之UDP编程
网络编程之UDP编程 UDP协议是一种不可靠的网络协议,它在通信的2端各建立一个Socket,但是这个Socket之间并没有虚拟链路,这2个Socket只是发送和接受数据的对象,Java提供了Data ...
- Java网络编程之InetAddress浅析
Java网络编程之InetAddress浅析 一.InetAddress综述 IP地址是IP使用的32位(IPv4)或者128位(IPv6)位无符号数字,它是传输层协议TCP,UDP的基础.InetA ...
- Java网络编程之URLConnection
Java网络编程之URLConnecton 一.URLConnection简介 URLConnection是一个抽象类,表示指向URL指定资源的活动连接.URLConnection有两个不同但相关的用 ...
- Java网络编程之URL和URI
Java网络编程之URL与URI 一.URL与URI简介 URI = Universal Resource Identifier 统一资源标志符 URL = Universal Resource Lo ...
随机推荐
- Linux就这个范儿 第9章 特种文件系统
Linux就这个范儿 第9章 特种文件系统 http://book.douban.com/reading/32081222/ P326 有一种文件系统,根本不在磁盘上.这种文件系统就是大名顶顶的ram ...
- Speed-BI 多事实表与表间计算的应用:销售目标达成分析 另一种实现方法
在前一篇<Speed-BI多事实表与表间计算的应用(excel多Sheet关联分析):销售目标达成分析>http://www.powerbibbs.com/forum. ... 7583& ...
- 解决:AppMsg - Warning: calling DestroyWindow in CWnd::~CWnd; OnDestroy or PostNcDestroy in derived class will not be called
类似的还有:AppMsg - Warning: Destroying non-NULL m_pMainWnd(这是因为你既没有自己delete,也没有调用DestroyWindow) 首先解决第一个, ...
- 继承Prototype实现语句不能写在动态原型法中的理解
阅读javascript高级编程中, 对动态原型法中写Prototype继承父类对象的不可行的现象,不甚理解. 书上说是技术原因,如下有问题代码: 但是把protype语句移到构造函数后面,就OK,如 ...
- Java基础之读文件——使用通道读取混合数据2(ReadPrimesMixedData2)
控制台程序,本例读取Java基础之写文件部分(PrimesToFile2)写入的Primes.txt. 方法二:设置一个任意容量的.大小合适的字节缓冲区并且使用来自文件的字节进行填充.然后整理出缓冲区 ...
- PAT 解题报告 1010. Radix (25)
1010. Radix (25) Given a pair of positive integers, for example, 6 and 110, can this equation 6 = 11 ...
- Troubleshooting JDK
收集整理下JDK自带的关于 Troubleshooting 的文档 Java 2 Platform, Standard Edition 5.0 Troubleshooting and Diagnost ...
- Swift游戏实战-跑酷熊猫 14 熊猫打滚
这节内容我们来实现熊猫打滚.思路是这样的,当熊猫起跳时记录他的Y坐标,落到平台上的时候再记录它的Y坐标.两个坐标之间的差要是大于一定数值就判断它从高处落下要进行打滚缓冲.至此跑酷熊猫已经像一个游戏的样 ...
- SQL封装、多态与重载
面向对象1.类:众多对象抽象出来的2.对象:类实例化出来的 3.类的定义关键字 class 4.类里面包含成员变量成员属性 成员方法 5.面向对象三大特性(1)封装目的:保护类,让类更加安全.做法:让 ...
- HttpContext.Current 的缺陷
了解ASP.NET的开发人员都知道它有个非常强大的对象 HttpContext,而且为了方便,ASP.NET还为它提供了一个静态属性HttpContext.Current来访问它,今天的博客打算就从H ...