SocketFlags 列舉

定義

指定通訊端的傳送和接收行為。

此列舉支援其成員值的位元組合。

C#
[System.Flags]
public enum SocketFlags
繼承
SocketFlags
屬性

欄位

名稱 Description
Broadcast 1024

表示廣播封包。

ControlDataTruncated 512

表示控制項資料無法放入內部 64 KB 的緩衝區,且已截斷。

DontRoute 4

傳送而不使用路由表。

MaxIOVectorLength 16

針對用來傳送和接收資料的 WSABUF 結構數目提供標準值。 .NET Framework 4.5 不支援此值。

Multicast 2048

表示多點傳送封包。

None 0

未針對此呼叫使用任何旗標。

OutOfBand 1

處理 Out-of-Band Data。

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