2016-08-03 8 views
1

읽을 바이트 수가 2 바이트 헤더로 시작되는 TCP 서버를 작성했습니다. 스트림에서 읽은 다음 클라이언트에 응답을 보내면 NetworkStream과 TcpClient가 모두 삭제됩니다. 문제는 Thread.Sleep() 줄의 주석 처리를 제거하지 않으면 클라이언트가 내 응답을 수신하지 않는 것입니다. 다음은 코드입니다.NetworkStream Sleep() 문제

using (var tcpClient = await tcpServer.AcceptTcpClientAsync()) 
{ 
    tcpClient.NoDelay = true; 

    using (var stream = tcpClient.GetStream()) 
    { 
     var twoBytesHeader = new TwoByteHeader(); 
     var headerBuffer = new byte[twoBytesHeader.HeaderLength]; 

     using (var binaryReader = new BinaryReader(stream, Encoding.ASCII, true)) 
     { 
      headerBuffer = binaryReader.ReadBytes(twoBytesHeader.HeaderLength); 

      int newOffset; 
      var msgLength = twoBytesHeader.GetMessageLength(headerBuffer, 0, out newOffset); 

      var buffer = binaryReader.ReadBytes(msgLength); 

      string msgASCII = Encoding.ASCII.GetString(buffer); 

      var bufferToSend = await ProcessMessage(msgASCII); 

      using (var binaryWriter = new BinaryWriter(stream, Encoding.ASCII, true)) 
      { 
       binaryWriter.Write(bufferToSend); 
       binaryWriter.Flush(); 
      } 

      //Thread.Sleep(1000); 
     } 
    } 
} 

슬립이 주석 처리되지 않은 경우 클라이언트는 응답을 수신 한 후 클라이언트가 disconected되었음을 나타냅니다. 이 문제의 이유를 알아낼 수 없습니다.

+0

데이터를 전송하는 데 오류가 없는지 확인해야하는 경우 비동기가 응답이 아닐 수도 있습니다. 보내고 싶다는 메시지를 보내고 확인한 다음 닫을 수 있습니까? – BugFinder

+0

응답 해 주셔서 감사합니다. 이 경우 WriteAsync를 기다리고 있으므로 모든 바이트가 전송 될 때까지 기다린 다음 연결을 닫습니다. 내가 잘못하고있는 뭔가가 있어야합니다. – GAG

답변

2

사용자가 지정한 값만큼 읽음이 있다고 가정합니다. 대신 적어도 하나의 바이트를 읽습니다. 귀하의 코드는이를 처리 할 수 ​​있어야합니다. BinaryReader.ReadBytes을 사용하면 정확한 바이트 수를 읽고 상용구 코드 일부를 제거 할 수 있습니다.

또한 최악의 인코딩 인 ASCII 인코딩을 사용하지 않아야합니다.

+0

스트림을 사용하여 읽을 때 발생할 수있는 문제점을 지적 해 주셔서 감사합니다. 인코딩의 경우 클라이언트가 ASCII로 인코딩 된 메시지를 전송할 때 선택의 여지가 없습니다. 어쨌든, 난 아직도 알아낼 수 없다, 왜 슬리핑() 후 stream.Flush() 클라이언트가 응답을 받게합니다. Nagle의 알고리즘에 대해 읽었지만 NoDelay 속성을 설정 한 것처럼 플러시 동작을 수행한다고 가정합니다. – GAG

+0

클라이언트가 손상되었을 수 있습니까? 코드를 게시하십시오.; 설명 된 문제로 인해 서버가 충돌하고 의존하지 않을 수 있습니다. 그래서 어쨌든 수정하고 새로운 코드를 게시해야합니다.; NetworkStream에서 플러시는 아무 것도하지 않습니다. 아무것도 바꿀 수 없다. – usr

+0

문제는 클라이언트가 내가 액세스 할 수없는 외부 응용 프로그램이라는 것입니다. 테스트를 위해 작성한 간단한 클라이언트가 정상적으로 작동합니다. 덕분에 당신이 제안한 내용을 변경하고 도움이되는지 확인합니다. – GAG