- 浏览: 1060282 次
- 性别:
- 来自: 南京
文章分类
- 全部博客 (501)
- dwr (6)
- javascript (84)
- oracle (66)
- jsp/servlet (18)
- ant (3)
- 基础知识 (12)
- EXT (10)
- My SQL (10)
- java (71)
- spring (37)
- 学习的对象 (2)
- Linux (24)
- 面试 (1)
- HTML/CSS (11)
- tomcat (11)
- 收藏夹 (2)
- Power Designer (2)
- struts.xml配置文件 (1)
- sturts2 (3)
- myeclipse (8)
- eclipse (7)
- Maven (34)
- SVN (3)
- SAP JCO (2)
- JBOSS (11)
- webservice (8)
- word (1)
- 敏捷开发 (1)
- sybase (4)
- Nexus (3)
- EhCache (3)
- log4j (3)
- Cookie (4)
- Session (4)
- CXF (7)
- AXIS (2)
- SSO (1)
- LDAP (1)
- velocity (2)
- Jquery (5)
- redis (2)
- http (4)
- dojo (1)
- Linux资源监控软件mnon的安装与运用 (1)
- notepad++ (1)
- EA (1)
- UML (1)
- JasperReports (1)
- 权限 (0)
- freemarker (4)
- Spring MVC (1)
- JMS (1)
- activeMQ (1)
- hession (3)
- 安全 (1)
- ibatis (2)
- log (1)
- nginx (1)
最新评论
-
winhbb:
我刚好遇到了一个问题(在可以依赖注入的场合有效):有两个模块A ...
解决Maven项目相互依赖/循环依赖/双向依赖的问题 -
nanjiwubing123:
long3ok 写道你好 XmlOutputFormatter ...
用XStream转换复杂XML -
zhoujianboy:
另外一个方法实现eclipse tomcat 热部署:http ...
eclipse下实现maven项目在tomcat容器热部署方法 -
long3ok:
你好 XmlOutputFormatter 请问这个类是在什么 ...
用XStream转换复杂XML -
ganbo:
总结的好,文章给力。
解决Maven项目相互依赖/循环依赖/双向依赖的问题
Datagram socket使用UDP来实现数据通讯,因此它不能保证数据能够到达目的地,但是由于它不需要专用的网络链接,所以它所需的资源相对少的多。
正在装载数据……
Datagram以包的方式发送数据,但它不能保证这些数据包以特定的顺序到达目的,因此包中往往需要包含序列号的信息,接收方可以根据序列号的信息决定是否所有的包都已收到,并按正常顺序重组这些包。
Java通过两个类DatagramSocket和DatagramPacket来支持Datagram socket。DatagramSocket实现了Datagram socket的基本功能,而DatagramPacket则提供了对包的一些支持。
DatagramSocket的几个重要方法:
(1) DatagramSocket():随机绑定一个有效的端口;
(2) DatagramSocket(int port):绑定指定的端口;
(3) Void send(DatagramPacket p):发送数据报,由于目的地的地址信息已包含在数据报中,所以不需要在本函数中提供地址信息;
(4) synchronized void receive(DatagramPacket p):接收数据包,线程安全;
(5) synchronized void close():关闭socket;
在DatagramSocket中并不区分ServerSocket和ClientSocket,如果一定要区分,那么发送的是client,而接收的是server。
DatagramPacket有以几个重要的方法:
(1) DatagramPacket(byte ibuf[], int ilength):用于接收数据报;
(2) DatagramPacket(byte ibuf[], int ilength, InetAddress iaddr, int iport):用于发送的数据报;
(3) byte[] getData();
(4) int getLength()
以下是完整的Datagram Socket的例子:
接收端,Server端代码:
说明:
(1) 这个例子中接收端的socket使用了多线程;
(2) 在构造函数中创建了DatagramSocket,并且使用了1114这个端口;
(3) 本例子的关键函数是run,它使用了死循环,在循环中使用了receive这方法来临听1114端口,如果1114端口没有请求数据到来,那么这个程序就一直停留在receive这个位置,不再往下执行;
(4) 当1114端有数据时,receive方法将接收到的DatagramPacket数据包放在packet这个对象中,然后解析其中的数据,获取发送方的地址信息;
(5) 然后再创建DatagramPacket包,并填充数据,发送到原接收端。
以下是发送端的代码:
客户端的代码与服务器端的代码基本相同,只是没有了循环,并且处理步骤与服务器端的基本相反。这也说明了Datagram Socket不真正区分Server和Client。
本文来源:http://blog.csdn.net/sunny3106/archive/2007/06/03/1636595.aspx
正在装载数据……
Datagram以包的方式发送数据,但它不能保证这些数据包以特定的顺序到达目的,因此包中往往需要包含序列号的信息,接收方可以根据序列号的信息决定是否所有的包都已收到,并按正常顺序重组这些包。
Java通过两个类DatagramSocket和DatagramPacket来支持Datagram socket。DatagramSocket实现了Datagram socket的基本功能,而DatagramPacket则提供了对包的一些支持。
DatagramSocket的几个重要方法:
(1) DatagramSocket():随机绑定一个有效的端口;
(2) DatagramSocket(int port):绑定指定的端口;
(3) Void send(DatagramPacket p):发送数据报,由于目的地的地址信息已包含在数据报中,所以不需要在本函数中提供地址信息;
(4) synchronized void receive(DatagramPacket p):接收数据包,线程安全;
(5) synchronized void close():关闭socket;
在DatagramSocket中并不区分ServerSocket和ClientSocket,如果一定要区分,那么发送的是client,而接收的是server。
DatagramPacket有以几个重要的方法:
(1) DatagramPacket(byte ibuf[], int ilength):用于接收数据报;
(2) DatagramPacket(byte ibuf[], int ilength, InetAddress iaddr, int iport):用于发送的数据报;
(3) byte[] getData();
(4) int getLength()
以下是完整的Datagram Socket的例子:
接收端,Server端代码:
import java.io.*; import java.net.*; class FortuneServer1 extends Thread { DatagramSocket ServerSocket; public FortuneServer1() { super("FortuneServer1"); try { ServerSocket = new DatagramSocket(1114); System.out.println("FortuneServer up and running..."); } catch (SocketException e) { System.err.println("Exception: couldn't create datagram socket"); System.exit(1); } } public static void main(String[] args) { FortuneServer1 server = new FortuneServer1(); server.start(); } public void run() { if (ServerSocket == null) return; while (true) { try { InetAddress address; int port; DatagramPacket packet; byte[] data = new byte[128]; packet = new DatagramPacket(data, data.length); ServerSocket.receive(packet); //如果1114端口没有请求到数据,就一直停留在这里等待数据接收 //如果接收到数据,则将数据包放在packet对象中,并在下面对其解析 address = packet.getAddress(); port = packet.getPort(); FileWriter fw = new FileWriter("Fortunes.txt");//创建新文件 PrintWriter out = new PrintWriter(fw); for(int i=0;i<data.length;i++){ out.print(data[i]+" "); } out.close(); System.out.println("Data has been writen to destination!"); //再次创建数据包,发送到接收的数据的端口 packet = new DatagramPacket(data, data.length, address, port); ServerSocket.send(packet); System.out.println("Respond has been made!"); } catch (Exception e) { System.err.println("Exception: " + e); e.printStackTrace(); } } } }
说明:
(1) 这个例子中接收端的socket使用了多线程;
(2) 在构造函数中创建了DatagramSocket,并且使用了1114这个端口;
(3) 本例子的关键函数是run,它使用了死循环,在循环中使用了receive这方法来临听1114端口,如果1114端口没有请求数据到来,那么这个程序就一直停留在receive这个位置,不再往下执行;
(4) 当1114端有数据时,receive方法将接收到的DatagramPacket数据包放在packet这个对象中,然后解析其中的数据,获取发送方的地址信息;
(5) 然后再创建DatagramPacket包,并填充数据,发送到原接收端。
以下是发送端的代码:
import java.net.*; class FortuneClient { public static void main(String args[]) { FortuneClient client = new FortuneClient(); System.out.println(client.getMessage()); } public String getMessage() { String fortune; try { DatagramSocket socket; DatagramPacket packet; byte[] data = new byte[128]; for(int i=0;i<data.length;i++){ Integer integer=new Integer(i); data[i]=integer.byteValue(); } socket = new DatagramSocket(); //packet = new DatagramPacket(data, data.length,InetAddress.getByName("127.0.0.1"), 1114); packet = new DatagramPacket(data, data.length,InetAddress.getLocalHost(), 1114); socket.send(packet); packet = new DatagramPacket(data, data.length); socket.receive(packet); fortune = new String(packet.getData()); socket.close(); } catch (UnknownHostException e) { System.err.println("Exception: host could not be found"); return null; } catch (Exception e) { System.err.println("Exception: " + e); e.printStackTrace(); return null; } return fortune; } }
客户端的代码与服务器端的代码基本相同,只是没有了循环,并且处理步骤与服务器端的基本相反。这也说明了Datagram Socket不真正区分Server和Client。
本文来源:http://blog.csdn.net/sunny3106/archive/2007/06/03/1636595.aspx
发表评论
-
个人草稿使用
2017-08-19 09:02 0深入理解JVM: http://www.cnblogs.co ... -
Thread.setDaemon详解
2015-04-24 21:31 895java中线程分为两种类型:用户线程和守护线程。通过Threa ... -
怎么使用 ConcurrentHashMap 才能是线程安全的?
2015-04-13 11:54 1498public class test { public ... -
21,tomcat关闭钩子
2014-12-31 10:36 723在很多环境下,在关闭应用程序的时候需要做一些清理工作。问题在于 ... -
Java NIO使用及原理分析 (一) 【转载】
2014-10-24 00:04 484【转载】: http://blog.csdn.net/wuxi ... -
Java 两个集合取交集
2014-10-14 21:16 3113public static Set intersectionS ... -
Calendar类roll和add的区别
2014-10-10 22:28 489import java.text.SimpleDateForm ... -
Gson通过借助TypeToken获取泛型参数的类型的方法
2014-09-30 00:26 626[size=medium]最近在使用Goo ... -
HashMap的遍历效率讨论
2014-09-27 20:41 825经常遇到对HashMap中的key和value值对的遍历操作, ... -
Java 泛型
2014-06-26 12:44 852关键字说明 ? 通配符类型 <? extends T&g ... -
Java泛型集合的理解
2014-06-26 00:05 502[size=medium]什么是泛型? 泛型(Generic ... -
关于java字节码框架ASM的学习
2014-06-19 19:22 883一、什么是ASM ASM是一个java字节码操纵框架, ... -
Java动态代理详解
2014-06-19 17:41 855Java动态代理详解: http: ... -
Java内存,字符串文章收集
2014-06-18 16:24 706java--String常量池问题的几个例子 . http:/ ... -
Java内存解析
2014-06-18 11:48 769栈、堆、常量池等虽同 ... -
Java的堆与非堆内存
2014-01-07 10:59 713堆(Heap)和非堆(Non-heap)内存 按照官方的说法: ... -
JMX 资料收集
2014-01-07 10:53 444JavaSky的专栏 http://blog.csdn.net ... -
JAVA 注解示例 详解
2013-11-12 09:36 820注解(Annotation) 为我们在代码中天界信息提供了 ... -
Java 泛型详解
2013-11-11 22:35 796http://www.360doc.com/content/1 ... -
Java中的Enum的使用与分析
2013-11-09 12:49 814enum枚举类型:在实际问 ...
相关推荐
用Matlab写的关于UDP(用户数据报协议)下的主机间的数据通讯。如需运行这个程序,只需把程序中的IP替换成你的主机IP地址即可
在IT行业中,UDP(User Datagram Protocol)是一种无连接的、不可靠的传输层协议,它在TCP/IP协议栈中占有重要地位。标题“udp_data.zip_cast2kc_udp 的data”暗示了这个压缩包可能包含与UDP通信相关的数据,可能是...
UDP(User Datagram Protocol)是传输层的一个协议,属于无连接的、不可靠的协议,它在互联网协议族中扮演着重要角色,特别是在实时性要求较高的应用中,如视频流、在线游戏等。UDP的主要特点包括低延迟、无须建立...
UDP(User Datagram Protocol)是一种无连接的传输层协议,相对于TCP(Transmission Control Protocol)而言,它更加轻量级,适合于实时应用或者对延迟敏感的通信场景。然而,UDP不提供诸如连接建立、数据排序或错误...
UDP(User Datagram Protocol)是一种无连接的、不可靠的传输层协议,它是互联网协议套件的一部分。相较于TCP,UDP提供了一种快速但不保证数据顺序或可靠性的通信方式,适用于实时应用,如在线视频流、在线游戏和...
C语言中的UDP(User Datagram Protocol)传输是一种无连接的、不可靠的传输层协议,适用于不需要建立连接且对传输质量要求不高的场景。它允许发送方将数据包(称为数据报)独立发送至接收方,但不保证数据的顺序、...
udpSocket->readDatagram(datagram.data(), datagram.size()); QString str = datagram.data(); udp_ui->TextEdit->insertPlainText(str.append(' ').toUpper()); ``` 这段代码首先通过`pendingDatagramSize()`获取...
UDP(User Datagram Protocol)是网络传输层协议之一,与TCP(Transmission Control Protocol)并行存在。UDP属于无连接协议,不提供数据包顺序保证、错误校正或流量控制,因此它更加轻量级,适用于对实时性要求高的...
网络UDP调试工具是一款专为IT专业人士设计的实用软件,它主要功能是协助用户进行UDP(User Datagram Protocol)网络通信的调试和测试。UDP是一种无连接的传输层协议,相较于TCP,它提供了更低延迟和更高效率的数据...
udpSocket->writeDatagram(datagram.data(), datagram.size()); ``` 至于QtUDP接收文件,可以将文件分块发送,每次发送一个小的缓冲区,然后在接收端重新组装成完整的文件。这需要维护一个文件接收状态,包括已接收...
其中,FINS(Factory Integrated Network System)协议是欧姆龙网络通信的一种核心协议,而FINS UDP则是FINS协议在UDP(User Datagram Protocol)上的实现,主要用于实现PLC与上位机或其它设备间的高速、低延迟的...
### UDP(User Datagram Protocol)详解 #### 一、概述 UDP(用户数据报协议)作为计算机网络中的一个关键传输层协议,在多种应用场景中扮演着重要角色。与TCP(传输控制协议)不同,UDP的设计理念更偏向于高效和...
udpSocket->readDatagram(datagram.data(), datagram.size(), &sender, &senderPort); // 处理接收到的datagram } } }; ``` 对于C#开发者,使用System.Net.Sockets命名空间中的UdpClient类可以方便地处理UDP...
QByteArray data = datagram.data(); // 获取数据 QHostAddress sender = datagram.senderAddress(); // 获取发送者地址 quint16 senderPort = datagram.senderPort(); // 获取发送者端口 // 进行数据处理... } ...
UDP(User Datagram Protocol)是一种无连接的、不可靠的传输层协议,它是互联网协议套件中的重要组成部分。在C#和C++等编程语言中,我们可以利用UDP进行网络通信,实现数据的快速发送和接收。 UDP的特点在于其轻量...
UDP(User Datagram Protocol)是互联网协议族中的一种无连接、不可靠的传输协议,与TCP(Transmission Control Protocol)相比,它的设计更为简单,主要适用于对实时性要求高的应用,如在线游戏、视频会议等。...
UDP(User Datagram Protocol)协议是传输层的一种无连接协议,它不建立连接也不保证数据的可靠传输。由于这种特性,UDP具有低延迟、资源消耗小的优点,因此常用于实时音视频传输、DNS查询等场景。然而,这也使得UDP...
UDP(User Datagram Protocol)是一种无连接的传输层协议,它在Internet协议族中扮演着重要的角色。相较于TCP(Transmission Control Protocol),UDP提供了更快速的数据传输,因为它不建立连接,也不保证数据的顺序...
UDP(User Datagram Protocol)是一种无连接的、不可靠的传输层协议,它是互联网协议套件中的重要组成部分。UDP不提供连接建立、数据确认、流量控制或拥塞控制等服务,因此它更适合对实时性要求高的应用,如在线视频...