TransmitFileOptions Enumeração

Definição

A enumeração TransmitFileOptions define valores usados em solicitações de transferência de arquivo.

Essa enumeração dá suporte a uma combinação bit a bit dos valores de membro.

public enum class TransmitFileOptions
[System.Flags]
public enum TransmitFileOptions
[<System.Flags>]
type TransmitFileOptions = 
Public Enum TransmitFileOptions
Herança
TransmitFileOptions
Atributos

Campos

Nome Valor Description
UseDefaultWorkerThread 0

Use o thread padrão para processar solicitações de transferência de arquivos longas.

Disconnect 1

Inicie uma desconexão no nível de transporte depois que todos os dados do arquivo tiverem sido enfileirados para transmissão. Quando usados com ReuseSocket, esses sinalizadores retornam o soquete para um estado desconectado e reutilizável após a transmissão do arquivo.

ReuseSocket 2

O identificador do soquete pode ser reutilizado quando a solicitação for concluída. Esse sinalizador só será válido se Disconnect também for especificado. Quando usados com Disconnect, esses sinalizadores retornam o soquete para um estado desconectado e reutilizável após a transmissão do arquivo.

WriteBehind 4

Conclua a solicitação de transferência de arquivo imediatamente, sem pendências. Se esse sinalizador for especificado e a transferência de arquivo for bem-sucedida, os dados serão aceitos pelo sistema, mas não necessariamente reconhecidos pelo final remoto. Não use esse sinalizador com o sinalizador e ReuseSocket sinalizadoresDisconnect.

UseSystemThread 16

Use threads do sistema para processar solicitações de transferência de arquivos longas.

UseKernelApc 32

Use APCs (chamadas de procedimento assíncronas) do kernel em vez de threads de trabalho para processar solicitações de transferência de arquivos longas. Solicitações longas são definidas como solicitações que exigem mais de uma única leitura do arquivo ou de um cache; a solicitação, portanto, depende do tamanho do arquivo e do comprimento especificado do pacote de envio.

Exemplos

O exemplo a seguir demonstra o uso de TransmitFileOptions uma chamada para Socket.SendFile. O arquivo "test.txt" está localizado no diretório raiz do computador local. Neste exemplo, um pré-cofre e um postbuffer de dados são criados e enviados para o host remoto com o arquivo. Para usar o thread padrão do sistema, UseDefaultWorkerThread é especificado.

// Establish the local endpoint for the socket.
IPHostEntry ipHost = Dns.GetHostEntry(Dns.GetHostName());
IPAddress  ipAddr = ipHost.AddressList[0];
IPEndPoint ipEndPoint = new IPEndPoint(ipAddr, 11000);

// Create a TCP socket.
Socket client = new Socket(AddressFamily.InterNetwork,
        SocketType.Stream, ProtocolType.Tcp);

// Connect the socket to the remote endpoint.
client.Connect(ipEndPoint);

// Send file fileName to the remote host with preBuffer and postBuffer data.
// There is a text file test.txt located in the root directory.
string fileName = "C:\\test.txt";

// Create the preBuffer data.
string string1 = String.Format("This is text data that precedes the file.{0}", Environment.NewLine);
byte[] preBuf = Encoding.ASCII.GetBytes(string1);

// Create the postBuffer data.
string string2 = String.Format("This is text data that will follow the file.{0}", Environment.NewLine);
byte[] postBuf = Encoding.ASCII.GetBytes(string2);

//Send file fileName with buffers and default flags to the remote device.
Console.WriteLine("Sending {0} with buffers to the host.{1}", fileName, Environment.NewLine);
client.SendFile(fileName, preBuf, postBuf, TransmitFileOptions.UseDefaultWorkerThread);

// Release the socket.
client.Shutdown(SocketShutdown.Both);
client.Close();

Comentários

Note

Os sinalizadores Disconnect e ReuseSocket retornar o soquete para um estado desconectado e reutilizável após a transmissão do arquivo. Esses sinalizadores não devem ser usados em um soquete em que a qualidade do serviço (QOS) foi solicitada, pois o provedor de serviços pode excluir imediatamente qualquer qualidade de serviço associada ao soquete antes da conclusão da transferência de arquivo. A melhor abordagem para um soquete habilitado para QOS é chamar Socket.Close quando a transferência de arquivo for concluída, em vez de depender desses sinalizadores.

Aplica-se a