UdpClient 类提供了一些简单的方法,用于在阻止同步模式下发送和接收无连接 UDP 数据报。 因为 UDP 是无连接传输协议,所以不需要在发送和接收数据前建立远程主机连接。但您可以选择使用下面两种方法之一来建立默认远程主机:

  • 使用远程主机名和端口号作为参数创建 UdpClient 类的实例。

  • 创建 UdpClient 类的实例,然后调用 Connect 方法。

可以使用在 UdpClient 中提供的任何一种发送方法将数据发送到远程设备。 使用 Receive 方法可以从远程主机接收数据。

UdpClient 方法还允许发送和接收多路广播数据报。 使用 JoinMulticastGroup 方法可以将 UdpClient 预订给多路广播组。 使用 DropMulticastGroup 方法可以从多路广播组中取消对 UdpClient 的预订。

/// <summary>
/// 客户端
/// </summary>
class UDPSender
{
static void Main(string[] args)
{
//创建一个UdpClient对象,0表示系统自动分配发送端口
//(若同时在本机运行服务端和客户端,则服务端接收和客户端发送需要使用不同端口,否则两个程序使用同一端口将引发冲突)
UdpClient udpSender = new UdpClient(); //连接到服务端并指定接收端口
udpSender.Connect("localhost", ); //连接到子网广播地址并指定接收端口
//udpSender.Connect("192.168.1.255", 11000);
//(在使用TCP/IP协议的网络中,主机标识段全为1的IP地址为广播地址,广播地址传送给主机标识段所涉及的所有计算机。
//例如,对于192.168.1.0(255.255.255.0)网段,其广播地址为192.168.1.255(255的2进制即为11111111),
//当发出目的地址为192.168.1.255时,它将分发给该网段上的所有计算机。) //把消息转换成字节流发送到服务端
byte[] sendBytes = Encoding.ASCII.GetBytes("Is anybody there?");
udpSender.Send(sendBytes, sendBytes.Length); //关闭链接
udpSender.Close();
}
}
/// <summary>
/// 服务端
/// </summary>
class UDPReceive
{
static void Main(string[] args)
{
//创建一个UdpClient对象,11000为接收端口
UdpClient udpReceive = new UdpClient(); //设置远程主机,(IPAddress.Any, 0)代表接收所有IP所有端口发送的数据
IPEndPoint remoteIpEndPoint = new IPEndPoint(IPAddress.Any, );//或 IPEndPoint remoteIpEndPoint = null; //监听数据,接收到数据后,把数据转换成字符串并输出
byte[] receiveBytes = udpReceive.Receive(ref remoteIpEndPoint);
string returnData = Encoding.ASCII.GetString(receiveBytes);
Console.WriteLine("This is the message you received " + returnData.ToString());
Console.WriteLine("This message was sent from " + remoteIpEndPoint.Address.ToString() + " on their port number " + remoteIpEndPoint.Port.ToString()); //关闭连接
udpReceive.Close();
}
}

备注:需要先运行服务端,再运行客户端。否则客户端在服务端运行之前就已经发出数据,则服务端不会接收到数据。


下面是使用 UdpClient 类进行多路广播组的简单例子,加入相同的广播组地址即可实现多播。多路广播地址的范围从 224.0.0.0 到 239.255.255.255 ,服务端和客户端使用同一广播地址即可实现多播。


/// <summary>
/// 多路广播组客户端
/// </summary>
class MulticastGroupClient
{
static void Main(string[] args)
{
//创建一个UdpClient对象,0表示系统自动分配发送端口
var client = new UdpClient(); //将广播地址添加到多路广播组,生存期(路由器跳数)为10
var ip = IPAddress.Parse("234.56.78.90");
client.JoinMulticastGroup(ip, ); //定义终结点(服务端IP和接收端口),把消息转换成字节流后发送到服务端
var multicast = new IPEndPoint(ip, );
byte[] bytes = Encoding.ASCII.GetBytes("Hello from multicast.");
client.Send(bytes, bytes.Length, multicast);
}
}
/// <summary>
/// 多路广播组服务端
/// </summary>
class MulticastGroupServer
{
static void Main(string[] args)
{
//创建一个UdpClient对象,7788为接收端口
var client = new UdpClient(); //将广播地址添加到多路广播组,生存期(路由器跳数)为10
var ip = IPAddress.Parse("234.56.78.90");
client.JoinMulticastGroup(ip, ); //设置远程主机,(IPAddress.Any, 0)代表接收所有IP所有端口发送的数据
var multicast = new IPEndPoint(IPAddress.Any, );//或 IPEndPoint multicast = null; //监听数据,接收到数据后,把数据转换成字符串并输出
byte[] bytes = client.Receive(ref multicast);
string msg = Encoding.ASCII.GetString(bytes);
Console.WriteLine(msg);
}
}

C#使用 UdpClient 类进行简单通信的例子的更多相关文章

  1. 经测试稳定可用的蓝牙链接通信Demo,记录过程中遇到的问题的思考和解决办法,并整理后给出一个Utils类可以简单调用来实现蓝牙功能

    说明:这是本人在蓝牙开发过程中遇到过的问题记录和分析,以及解决办法. 在研究过程中,许多的前人给出的解决方案和思路指导对我相当有帮助,但并非都是可采取的解决方法, 经过本人对这些方法的测试和使用过后, ...

  2. DataAccess通用数据库访问类,简单易用,功能强悍

    以下是我编写的DataAccess通用数据库访问类,简单易用,支持:内联式创建多个参数.支持多事务提交.支持参数复用.支持更换数据库类型,希望能帮到大家,若需支持查出来后转换成实体,可以自行扩展dat ...

  3. java中Color类的简单总结

    java中Color类的简单总结 1.颜色的常识 任何颜色都是由三原色组成(RGB),JAVA中支持224为彩色,即红绿蓝分量取值 介于0-255之间(8位表示) 2.Color类中的常量 publi ...

  4. 【JAVA零基础入门系列】Day12 Java类的简单应用

    俗话说的好,实践出真知,所以除了理论知识掌握扎实以外,更重要的是要多加操练,这样才能掌握核心科技. 今天我们就用刚学会的类来实践一下,目标便是完成上一篇中的剁手任务. 我们的商品类已经准备好了,代码重 ...

  5. Java开发笔记(四十八)类的简单继承

    前面介绍了类的基本用法,主要是如何封装一个类的各项要素,包括成员属性.成员方法.构造方法等,想必大家对类的简单运用早已驾轻就熟.所谓“物以类聚,人以群分”,之所以某些事物会聚在一起,乃是因为它们拥有类 ...

  6. Eclipse搭建服务器,实现与Android的简单通信

    ---恢复内容开始--- 目标:实现客户端(Android App)与服务器(PC)的简单通信 相关准备:eclipse_mars.tomcat8.Android Studio 实现: 1.java环 ...

  7. python 元类的简单解释

    本文转自博客:http://www.cnblogs.com/piperck/p/5840443.html 作者:piperck python 类和元类(metaclass)的理解和简单运用 (一) p ...

  8. rocketmq中的NettyRemotingClient类的简单分析

    rocketmq中的NettyRemotingClient类的简单分析 Bootstrap handler = this.bootstrap.group(this.eventLoopGroupWork ...

  9. 面试:vector类的简单实现

    vector类的简单实现 #include <vector> #include <iostream> #include <cstring> #include < ...

随机推荐

  1. 表单验证Jquery扩展方法类

    /** 表单数据验证 **/ $.fn.Validform = function () { var Validatemsg = ""; var Validateflag = tru ...

  2. 用户管理 之 在Linux系统中,批量添加用户的操作流程

    一.阅读此文件您需要掌握的基础知识: <Linux 用户(user)和用户组(group)管理概述><用户(user)和用户组(group)配置文件详解><Linux 用 ...

  3. java代写

    Computer Science, Claremont McKenna CollegeCS51.2 - Introduction to Computer Science, Fall 2014Probl ...

  4. SQL语句删除所有表

    ) )     ) )     ) )     ) ) )  TABLE_NAME  CONSTRAINT_NAME  CONSTRAINT_NAME  TABLE_NAME ) ) )  TABLE ...

  5. Python的Descriptor和Property混用

    一句话,把Property和Descriptor作用在同一个名字上,就只有Property好使.

  6. Java对象生命周期

    [TOC] 1. 创建阶段(Created) 为对象分配存储空间 开始构造对象 从父类到子类对static成员进行初始化 父类成员变量按照顺序初始化,递归调用父类的构造方法 子类成员变量按照顺序初始化 ...

  7. C#集合--ICollection接口和IList接口

    虽然列举接口提供了一个协议,用于向前的方式遍历集合,但它们没有提供一种机制来确定集合的大小,通过索引访问集合的成员,搜索集合,或修改集合.为了实现这些功能,.NET Framework定义了IColl ...

  8. Jenkins:”ResourceRules.plist: cannot read resources” error after Xcode 6.1

    在 Custom xcodebuild arguments 处填入: "CODE_SIGN_RESOURCE_RULES_PATH=$(SDKROOT)/ResourceRules.plis ...

  9. Hadoop - 实时查询Drill

    1.概述 在现实业务当中,存在这样的业务场景,需要实时去查询HDFS上的相关存储数据,普通的查询(如:Hive查询),时延较高.那么,是否存在时延较小的查询组件.在业界目前较为成熟的有Cloudera ...

  10. (笔记)Linux内核学习(十)之虚拟文件系统概念

    虚拟文件系统 虚拟文件系统:内核子系统VFS,VFS是内核中文件系统的抽象层,为用户空间提供文件系统相关接口: 通过虚拟文件系统,程序可以利用标准Linux文件系统调用在不同的文件系统中进行交互和操作 ...