
Java ソケット API での接続終了の決定: isConnected() と isClosed() を超えて
Java ソケット API には、接続を確立するための便利な方法が用意されています。接続では、ソケットの閉鎖を検出することが困難になる場合があります。 isConnected() メソッドは、接続がリモートで閉じられた場合でも true を返し、ソケットがローカルで明示的に閉じられるまで isClosed() は false を返します。
この制限を克服するために、いくつかのオプションが利用可能です。
-
入出力ストリームの監視: 閉じられたソケットから読み取りまたは書き込みを試みると、次のような例外が発生します。読み取りの場合は EOFException、書き込みの場合は IOException。このメソッドでは、クロージャを検出するために一定のデータ交換が必要です。
-
読み取りタイムアウトの利用: 読み取りタイムアウトは、読み取り操作が完了するまでの最大間隔を指定します。読み取りがタイムアウトした場合、ピアが切断されていることを示す可能性があります。
-
OP_READ で SelectionKey を使用する: 特定の条件下で、選択後に無効なキーを返す有効な SelectionKey を使用して OP_READ を選択すると、ピアが切断されていることを示す可能性があります。ピアからの接続のリセット。ただし、この動作は JRE のバージョンとプラットフォームによって異なる場合があります。
追加の考慮事項:
- ClosedChannelException は、問題を示す信頼できるインジケータではありません。閉じた接続。これは、チャネルがローカルで明示的に閉じられていることを示します。
- 一部のリソースでは、キープアライブ フラグの監視を推奨しています。ただし、キープアライブはデフォルトで有効になっているため、キープアライブが存在しないからといって必ずしも接続が閉じられたことを示すわけではありません。
結論:
Java でのソケット クロージャの決定には、以下が必要です。慎重な検討とテクニックの組み合わせ。読み取りと書き込みによるクロージャの検出は非効率的に見えるかもしれませんが、ほとんどのシナリオに対して堅牢なソリューションを提供します。読み取りタイムアウトやSelectionKeyモニタリングなどの他のオプションは、特定の状況で代替アプローチを提供できます。
以上が「isConnected()」と「isClosed()」を超えて Java ソケットのクローズを確実に検出するにはどうすればよいですか?の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。