2013-03-05 17 views
8

Ho scritto un semplice server TCP asincrono: funziona bene. Ma ora voglio fare un output dei dati ricevuti sul programma Console-Test. E il problema è che questo non funziona! Se connetto il MainThread all'EventHandler il programma non fa nulla. Debug sta mostrando che sc05Server_DataAvailable è stato chiamato ma poi non è successo nulla. Il programma è ancora reattivo.Console.Writeline da EventHandler

Ecco il codice:

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; 
    } 
} 

Il programma principale:

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 
    } 
} 

Penso che abbia qualcosa a che fare con Threading - ma non ho idea di come lavorare con loro.

+0

puoi pubblicare il tipo di evento? L'evento che viene collegato all'interno di Sc05BdServer. –

+0

Sei sicuro che non sta entrando nella condizione 'se' e ​​ritorno? Hai inserito un punto di interruzione nel gestore per vedere se il numero di byte letti è 0? –

+0

@JimMischel sì Sono sicuro che System.Diagnostics.Debug.Print sta facendo l'output. – GreenEyedAndy

risposta