Comparteix a través de


Socket.EndSend Método

Definición

Finaliza un envío asincrónico pendiente.

Sobrecargas

EndSend(IAsyncResult)

Finaliza un envío asincrónico pendiente.

EndSend(IAsyncResult, SocketError)

Finaliza un envío asincrónico pendiente.

EndSend(IAsyncResult)

Source:
Socket.cs
Source:
Socket.cs
Source:
Socket.cs

Finaliza un envío asincrónico pendiente.

public:
 int EndSend(IAsyncResult ^ asyncResult);
public int EndSend (IAsyncResult asyncResult);
member this.EndSend : IAsyncResult -> int
Public Function EndSend (asyncResult As IAsyncResult) As Integer

Parámetros

asyncResult
IAsyncResult

IAsyncResult que almacena información de estado para esta operación asincrónica.

Devoluciones

Si se realiza con éxito, el número de bytes enviados al objeto Socket; en caso contrario, un error de Socket no válido.

Excepciones

asyncResult es null.

asyncResult no se devolvió mediante una llamada al método BeginSend(Byte[], Int32, Int32, SocketFlags, AsyncCallback, Object).

EndSend(IAsyncResult) fue llamado previamente para el envío asincrónico.

Error al intentar acceder al socket.

o bien

Solo .NET 7+: Socket se ha cerrado.

Solo .NET Framework, .NET Core y .NET 5-6: Socket se ha cerrado .

Comentarios

Importante

Se trata de una API de compatibilidad. No se recomienda usar los métodos de APM (Begin* y End*) para el nuevo desarrollo. En su lugar, use los Taskequivalentes basados en .

EndSend completa la operación iniciada por BeginSend. Debe pasar el IAsyncResult objeto creado por la llamada coincidente BeginSend .

Si usa un protocolo sin conexión, EndSend se bloqueará hasta que se envíe el datagrama. Si usa un protocolo orientado a la conexión, EndSend se bloqueará hasta que se envíe parte del búfer. Si el valor devuelto de EndSend indica que el búfer no se envió por completo, llame BeginSend al método de nuevo, modificando el búfer para contener los datos no enviados.

No hay ninguna garantía de que los datos que envíe aparecerán en la red inmediatamente. Para aumentar la eficiencia de la red, el sistema subyacente puede retrasar la transmisión hasta que se recopile una cantidad significativa de datos salientes. Una finalización correcta del BeginSend método significa que el sistema subyacente ha tenido espacio para almacenar en búfer los datos de un envío de red.

Nota

Si recibe un SocketException, use la SocketException.ErrorCode propiedad para obtener el código de error específico.

Nota

Todas las E/S iniciadas por un subproceso determinado se cancelan cuando se cierra ese subproceso. Se puede producir un error en una operación asincrónica pendiente si el subproceso sale antes de que se complete la operación.

Nota

La finalización correcta de un envío no indica que los datos se entregaron correctamente. Si no hay espacio en búfer disponible en el sistema de transporte para contener los datos que se van a transmitir, el envío se bloqueará a menos que el socket se haya colocado en modo de no bloqueo.

Nota

Este miembro genera información de seguimiento cuando se habilita el seguimiento de red en la aplicación. Para obtener más información, consulte Seguimiento de red en .NET Framework.

Consulte también

Se aplica a

EndSend(IAsyncResult, SocketError)

Source:
Socket.cs
Source:
Socket.cs
Source:
Socket.cs

Finaliza un envío asincrónico pendiente.

public:
 int EndSend(IAsyncResult ^ asyncResult, [Runtime::InteropServices::Out] System::Net::Sockets::SocketError % errorCode);
public int EndSend (IAsyncResult asyncResult, out System.Net.Sockets.SocketError errorCode);
member this.EndSend : IAsyncResult * SocketError -> int
Public Function EndSend (asyncResult As IAsyncResult, ByRef errorCode As SocketError) As Integer

Parámetros

asyncResult
IAsyncResult

IAsyncResult que almacena información de estado para esta operación asincrónica.

errorCode
SocketError

Objeto SocketError que almacena el error de socket.

Devoluciones

Si se realiza con éxito, el número de bytes enviados al objeto Socket; en caso contrario, un error de Socket no válido.

Excepciones

asyncResult es null.

asyncResult no se devolvió mediante una llamada al método BeginSend(Byte[], Int32, Int32, SocketFlags, AsyncCallback, Object).

EndSend(IAsyncResult) fue llamado previamente para el envío asincrónico.

Error al intentar acceder al socket.

o bien

Solo .NET 7+: Socket se ha cerrado.

Solo .NET Framework, .NET Core y .NET 5-6: Socket se ha cerrado .

Comentarios

Importante

Se trata de una API de compatibilidad. No se recomienda usar los métodos de APM (Begin* y End*) para el nuevo desarrollo. En su lugar, use los Taskequivalentes basados en .

EndSend completa la operación iniciada por BeginSend. Debe pasar el IAsyncResult objeto creado por la llamada coincidente BeginSend .

Si usa un protocolo sin conexión, EndSend se bloqueará hasta que se envíe el datagrama. Si usa un protocolo orientado a la conexión, EndSend se bloqueará hasta que se envíe parte del búfer. Si el valor devuelto de EndSend indica que el búfer no se envió por completo, llame BeginSend al método de nuevo, modificando el búfer para contener los datos no enviados.

No hay ninguna garantía de que los datos que envíe aparecerán en la red inmediatamente. Para aumentar la eficiencia de la red, el sistema subyacente puede retrasar la transmisión hasta que se recopile una cantidad significativa de datos salientes. Una finalización correcta del BeginSend método significa que el sistema subyacente ha tenido espacio para almacenar en búfer los datos de un envío de red.

Nota

Si recibe un SocketException, use la SocketException.ErrorCode propiedad para obtener el código de error específico.

Nota

Todas las E/S iniciadas por un subproceso determinado se cancelan cuando se cierra ese subproceso. Se puede producir un error en una operación asincrónica pendiente si el subproceso sale antes de que se complete la operación.

Nota

La finalización correcta de un envío no indica que los datos se entregaron correctamente. Si no hay espacio en búfer disponible en el sistema de transporte para contener los datos que se van a transmitir, el envío se bloqueará a menos que el socket se haya colocado en modo de no bloqueo.

Nota

Este miembro genera información de seguimiento cuando se habilita el seguimiento de red en la aplicación. Para obtener más información, consulte Seguimiento de red en .NET Framework.

Consulte también

Se aplica a