gpt4 book ai didi

c# - 具有多个发送方和一个接收方的 UDP

转载 作者:行者123 更新时间:2023-12-03 12:00:29 26 4
gpt4 key购买 nike

在一个项目中,我有多个 UDP 数据发送者,但只有一个接收者。

如果流量变大,接收方会“忘记”大量数据包。我知道这是 UDP 固有的问题,但我想尽量减少丢失数据包的数量。

我已阅读 this之前的问题!

这是我的代码(请原谅大量的代码块,但我希望该示例是自包含的)

发送方:

public class UdpSender
{
private static int portNumber = 15000;

public void Send(string data)
{
var udpServer = new UdpClient();
var ipEndPoint = new IPEndPoint(IPAddress.Broadcast, portNumber);
byte[] bytes = Encoding.ASCII.GetBytes(data);
udpServer.Send(bytes, bytes.Length, ipEndPoint);
udpServer.Close();
}
}


class Program
{
static void Main(string[] args)
{
var sender = new UdpSender();
var count = 100000;

for (var i = 0; i < count; ++i)
{
sender.Send(i.ToString());
}

Console.ReadKey();
}
}

接收方:
public class UDPListener
{
private static int portNumber = 15000;
private readonly UdpClient udp = new UdpClient(portNumber);

public volatile int CountOfReceived = 0;

public void StartListening()
{
this.udp.BeginReceive(Receive, new object());
}

private void Receive(IAsyncResult ar)
{
Interlocked.Increment(ref CountOfReceived);

IPEndPoint ip = new IPEndPoint(IPAddress.Any, portNumber);
byte[] bytes = udp.EndReceive(ar, ref ip);
string message = Encoding.ASCII.GetString(bytes);
StartListening();
}
}

class Program
{
static void Main(string[] args)
{
var listener = new UDPListener();

listener.StartListening();

while (true)
{
Console.WriteLine(listener.CountOfReceived.ToString("000,000,000"));
}

}
}

现在,如果我并行启动 5 个发送方应用程序,则只会收到大约四分之一的消息。这仅在我的本地计算机上。

我可以做些什么来最大程度地减少数据包丢失?

最佳答案

考虑到您在旅途中发送数据包的速度,我会说 sinks 缓冲区可能会在一段时间内被填充 - 我想增加缓冲区大小(如图所示 here )可以解决这个问题。

关于c# - 具有多个发送方和一个接收方的 UDP,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/25162549/

26 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com