0

Java: 1.7 OS: Linux (ただし、どの Linux かはわかりません)

ソケットの BufferedReader から読み取ったものを含む CharBuffer があります。確かにソケットが確立されました。それをダンプしようとすると、ERROR_FORMATの結果が得られます。

その後、ソケットからデータを読み込みましたが、java.net.SocketException: Connection resetが発生しました

接続リセットの問題は私が修正している問題でしたが、どうしてCharBuffer.toString()ERROR_FORMATの結果を返すのでしょうか?

以下は私のコードですが、何か問題がありますか?

Socket connectionSocket=xxxxxx;  //Connected socket given by other library

connectionSocket.setSoTimeout(75*1000);
CharBuffer charBuffer=CharBuffer.allocate(1024);
BufferedReader bufferedReader=null;

bufferedReader=new BufferedReader(new InputStreamReader(connectionSocket.getInputStream(), "BIG5"));

while((bufferedReader.read(charBuffer))!=-1)  // in 2nd time, this line throw a java.net.SocketException: Connection reset
{
  charBuffer.flip();
  respStr.append(charBuffer);
  log.info("CharBuffer: "+charBuffer.toString());  // this line runs just 1 tine, print result: "CharBuffer: 2016102618353211301 : ERROR_FORMAT"
  charBuffer.clear();
}
log.info("CharBuffer all: "+charBuffer.toString());  // dodn't been execute
4

1 に答える 1

0

問題を再現できませんでした

public static void main(String[] args) throws IOException {
    StringBuilder respStr = new StringBuilder();
    CharBuffer charBuffer=CharBuffer.allocate(1024);
    BufferedReader bufferedReader=null;
    Logger log = Logger.getAnonymousLogger();

    // create a byte stream with some big 5 characters in it
    // to simulate what a socket should produce
    byte[] bytes = new byte[100];
    int index = 0;
    for(int i = 0xc940;i<0xc940+50;i++){
        bytes[index++] = (byte)((i & 0x0ff00)>>8);
        bytes[index++] = (byte)((i & 0x0ff));
    }
    InputStream byteStream = new ByteArrayInputStream(bytes);

    // code to process the byte stream
    bufferedReader=new BufferedReader(new InputStreamReader(byteStream, "BIG5"));
    while((bufferedReader.read(charBuffer))!=-1){
        charBuffer.flip();
        respStr.append(charBuffer);
        log.info("CharBuffer: "+charBuffer.toString());
        charBuffer.clear();
    }
    log.info("CharBuffer all: "+charBuffer.toString());
}

2016 年 10 月 27 日 6:27:18 PM nz.test.buffers.CharBufferTest メイン

INFO: CharBuffer: <漢字>

2016 年 10 月 27 日 6:27:18 PM nz.test.buffers.CharBufferTest メイン

INFO: CharBuffer all: < 漢字 >

于 2016-10-27T05:29:39.260 に答える