2013-03-05 65 views
8

我寫了一個簡單的異步TCP服務器 - 它運行良好。但是現在我想在Console-Testprogram上輸出接收到的數據。問題是,這是行不通的!如果我將MainThread連接到EventHandler,那麼程序不會執行任何操作。調試顯示sc05Server_DataAvailable被調用,但沒有發生任何事情。該計劃仍然有響應。來自EventHandler的Console.Writeline

這裏的代碼:

private void ReadCallback(IAsyncResult asyncResult) 
{ 
    Sc05BdClient sc05BdClient = asyncResult.AsyncState as Sc05BdClient; 
    if (sc05BdClient == null) return; 
    NetworkStream networkStream = sc05BdClient.NetworkStream; 
    int read = networkStream.EndRead(asyncResult); 

    if (read == 0) 
    { 
     lock (clients) 
     { 
      clients.Remove(sc05BdClient); 
      return; 
     } 
    } 

    string data = Encoding.GetString(sc05BdClient.Buffer, 0, read); 
    System.Diagnostics.Debug.Print(data); 
    OnDataAvailable(this, new DataAvailableEventArgs(data)); <---- here Handler is called 
    networkStream.BeginRead(sc05BdClient.Buffer, 0, sc05BdClient.Buffer.Length, ReadCallback, sc05BdClient); 
} 


public event EventHandler<DataAvailableEventArgs> DataAvailable; 

protected virtual void OnDataAvailable(object sender, DataAvailableEventArgs e) 
{ 
    EventHandler<DataAvailableEventArgs> handler = DataAvailable; 
    if (handler != null) 
     handler(sender, e); 
} 


public class DataAvailableEventArgs : EventArgs 
{ 
    public string Data; 

    public DataAvailableEventArgs(string data) 
    { 
     Data = data; 
    } 
} 

主程序:

class Program 
{ 
    static void Main() 
    { 
     Sc05BdServer sc05BdServer = new Sc05BdServer(IPAddress.Any, 2006); 
     sc05BdServer.DataAvailable += sc05BdServer_DataAvailable; 
     sc05BdServer.Start(); 

     Console.ReadKey(); 
     sc05BdServer.Stop(); 
    } 

    static void sc05BdServer_DataAvailable(object sender, DataAvailableEventArgs e) 
    { 
     Console.WriteLine(e.Data); <--- this is called once 
    } 
} 

我認爲這是與線程 - 但我不知道如何與他們合作。

+0

您可以發佈您的活動的類型?正在Sc05BdServer內部連接的事件。 – 2013-03-05 19:19:14

+0

你確定它沒有進入'if'條件並返回?你是否在處理程序中放置了一個斷點以查看讀取的字節數是否爲0? – 2013-03-05 19:31:52

+0

@JimMischel是的我確定System.Diagnostics.Debug.Print正在做它的輸出。 – GreenEyedAndy 2013-03-05 19:40:58

回答