Socket.EndSendFile メソッド
アセンブリ: System (system.dll 内)


例外の種類 | 条件 |
---|---|
NotSupportedException | このメソッドには Windows NT が必要です。 |
ObjectDisposedException | |
ArgumentNullException | asyncResult が空です。 |
ArgumentException | |
InvalidOperationException | |
SocketException |

EndSendFile は、BeginSendFile で開始された非同期送信操作を完了します。
BeginSendFile を呼び出す前に、AsyncCallback デリゲートを実装するコールバック メソッドを作成する必要があります。このコールバック メソッドは個別のスレッドで実行され、BeginSendFile の終了時に呼び出されます。コールバック メソッドは、BeginSendFile メソッドからパラメータとして返された IAsyncResult オブジェクトを受け取る必要があります。
コールバック メソッド内では、IAsyncResult パラメータの AsyncState メソッドを呼び出して送信 Socket を取得します。Socket を取得したら、EndSendFile メソッドを呼び出して送信操作を正常に完了できます。
コネクションレスのプロトコルを使用している場合、EndSendFile は、データグラムが送信されるまでブロックします。コネクション指向のプロトコルを使用している場合、EndSendFile は、ファイル全体が送信されるまでブロックします。送信したデータがすぐにネットワーク上に現れることは保証されません。ネットワークの効率を高めるため、基になっているシステムは、十分な量の送信データが収集されるまで送信を遅延することがあります。BeginSendFile メソッドが正常に完了した場合は、基になるシステムにネットワーク送信のためにデータをバッファする余地があったことを示します。
![]() |
---|
SocketException が発生した場合は、SocketException.ErrorCode プロパティを使用して具体的なエラー コードを取得してください。このコードを取得したら、Windows Socket Version 2 API エラー コードのドキュメントでエラーの詳細情報を確認してください。これは MSDN ライブラリから入手できます。 |

非同期通信のソケットを作成して接続し、リモート ホストにファイル "text.txt" の非同期的な送信を開始するコード例を次に示します。コールバック デリゲートが EndSendFile を呼び出し、伝送を完了します。
public static void AsynchronousFileSend() { // Send a file to a remote device. // Establish the remote endpoint for the socket. IPHostEntry ipHostInfo = Dns.Resolve(Dns.GetHostName()); IPAddress ipAddress = ipHostInfo.AddressList[0]; IPEndPoint remoteEP = new IPEndPoint(ipAddress, 11000); // Create a TCP/IP socket. Socket client = new Socket(AddressFamily.InterNetwork, SocketType.Stream, ProtocolType.Tcp); // Connect to the remote endpoint. client.BeginConnect(remoteEP, new AsyncCallback(ConnectCallback), client); // Wait for connect. connectDone.WaitOne(); // There is a text file test.txt in the root directory. string fileName = "C:\\test.txt"; // Send file fileName to the remote device. Console.WriteLine(fileName); client.BeginSendFile(fileName, new AsyncCallback(FileSendCallback), client); // Release the socket. client.Shutdown(SocketShutdown.Both); client.Close(); } private static void FileSendCallback(IAsyncResult ar) { // Retrieve the socket from the state object. Socket client = (Socket) ar.AsyncState; // Complete sending the data to the remote device. client.EndSendFile(ar); sendDone.Set(); }

Windows 98, Windows 2000 SP4, Windows Millennium Edition, Windows Server 2003, Windows XP Media Center Edition, Windows XP Professional x64 Edition, Windows XP SP2, Windows XP Starter Edition
開発プラットフォームの中には、.NET Framework によってサポートされていないバージョンがあります。サポートされているバージョンについては、「システム要件」を参照してください。


Weblioに収録されているすべての辞書からSocket.EndSendFile メソッドを検索する場合は、下記のリンクをクリックしてください。

- Socket.EndSendFile メソッドのページへのリンク