SocketFlags 枚举

定义

指定套接字发送和接收行为。

此枚举支持其成员值的按位组合。

C#
[System.Flags]
public enum SocketFlags
继承
SocketFlags
属性

字段

名称 说明
Broadcast 1024

指示广播数据包。

ControlDataTruncated 512

指示控制数据无法放入 64 KB 的内部缓冲区且已被截断。

DontRoute 4

不使用路由表进行发送。

MaxIOVectorLength 16

提供用于发送和接收数据的 WSABUF 结构数的标准值。 .NET Framework 4.5 上不使用或不支持此值。

Multicast 2048

指示多播数据包。

None 0

不对此调用使用任何标志。

OutOfBand 1

处理带外数据。

Partial 32768

部分发送或接收消息。

Peek 2

快速查看传入消息。

Truncated 256

消息太大,无法放入指定的缓冲区,并且已被截断。

示例

以下示例发送数据并指定 SocketFlags.None

C#
// Displays sending with a connected socket
// using the overload that takes a buffer, message size, and socket flags.
public static int SendReceiveTest3(Socket server)
{
    byte[] msg = Encoding.UTF8.GetBytes("This is a test");
    byte[] bytes = new byte[256];
    try
    {
        // Blocks until send returns.
        int i = server.Send(msg, msg.Length, SocketFlags.None);
        Console.WriteLine("Sent {0} bytes.", i);

        // Get reply from the server.
        int byteCount = server.Receive(bytes, bytes.Length, SocketFlags.None);
        if (byteCount > 0)
            Console.WriteLine(Encoding.UTF8.GetString(bytes, 0, byteCount));
    }
    catch (SocketException e)
    {
        Console.WriteLine("{0} Error code: {1}.", e.Message, e.ErrorCode);
        return (e.ErrorCode);
    }
    return 0;
}

适用于

产品 版本
.NET Core 1.0, Core 1.1, Core 2.0, Core 2.1, Core 2.2, Core 3.0, Core 3.1, 5, 6, 7, 8, 9
.NET Framework 1.1, 2.0, 3.0, 3.5, 4.0, 4.5, 4.5.1, 4.5.2, 4.6, 4.6.1, 4.6.2, 4.7, 4.7.1, 4.7.2, 4.8, 4.8.1
.NET Standard 1.3, 1.4, 1.6, 2.0, 2.1