2010-01-22 33 views
9

tengo error se muestra: Error en 'Timer' es una referencia ambigua entre 'System.Windows.Forms.Timer' y 'System.Threading.Timer'

 
'Timer' is an ambiguous reference between 'System.Windows.Forms.Timer' and 'System.Threading.Timer' 
cuando he añadido el código para el reloj

using System; 
using System.Collections.Generic; 
using System.ComponentModel; 
using System.Data; 
using System.Drawing; 
using System.Linq; 
using System.Text; 
using System.Windows.Forms; 
using System.Net.Sockets; 
using System.Threading; 
using System.Security.Cryptography; 


namespace SocketClient 
{ 

    public partial class SocketClient : Form 
    { 
     System.Net.Sockets.TcpClient clientSocket = new System.Net.Sockets.TcpClient(); 
     NetworkStream serverStream = default(NetworkStream); 
     string readData = null; 


     public SocketClient() 
     { 
      InitializeComponent(); 
      Timer timer = new Timer(); 
      timer.Tick += new EventHandler(TimerOnTick); 
      timer.Interval = 1000; 
      timer.Start(); 
     } 



     private void TimerOnTick(object sender, EventArgs ea) 
     { 
      Invalidate(); 
     } 

     protected override void OnPaint(PaintEventArgs pea) 
     { 
      StringFormat strfmt = new StringFormat(); 
      strfmt.Alignment = StringAlignment.Far; 
      strfmt.LineAlignment = StringAlignment.Far; 

      pea.Graphics.DrawString(DateTime.Now.ToString("F"), 
      Font, new SolidBrush(ForeColor), 
      ClientRectangle, strfmt); 

     } 

     private void getMessage() 
     { 
      while (true) 
      { 
       serverStream = clientSocket.GetStream(); 
       int buffSize = 0; 
       byte[] inStream = new byte[10025]; 
       buffSize = clientSocket.ReceiveBufferSize; 
       serverStream.Read(inStream, 0, buffSize); 
       string returndata = System.Text.Encoding.ASCII.GetString(inStream); 
       readData = "" + returndata; 
       msg(); 
      } 
     } 


     private void msg() 
     { 
      if (this.InvokeRequired) 
       this.Invoke(new MethodInvoker(msg)); 
      else 
       textDisplay.Text = textDisplay.Text + Environment.NewLine + " >> " + readData; 
     } 


     private void buttonConnect_Click(object sender, EventArgs e) 
     { 


      // show the message if no input is enter. 
      if (string.IsNullOrEmpty(textName.Text) || string.IsNullOrEmpty(textPort.Text) || string.IsNullOrEmpty(textIP.Text)) 
      { 
       MessageBox.Show("Please enter Name, IP Address & Port #"); 
      } 
      else 
      { 
       //connect to the server if all 3 input is enter 
       readData = "Conected to NYP Server ..."; 
       msg(); 

       clientSocket.Connect(textIP.Text, Convert.ToInt32(textPort.Text)); 
       serverStream = clientSocket.GetStream(); 

       byte[] outStream = System.Text.Encoding.ASCII.GetBytes(textName.Text + "$"); 
       serverStream.Write(outStream, 0, outStream.Length); 
       serverStream.Flush(); 

       Thread ctThread = new Thread(getMessage); 
       ctThread.Start(); 


      } 
     } 

     private void buttonSend_Click(object sender, EventArgs e) 
     { 
      // Show msg box if no server is connected 
      if (serverStream == null) 
      { 
       MessageBox.Show("Please connect to a server first!"); 
       return; 
      } 

      // Send text 
      byte[] outStream = System.Text.Encoding.ASCII.GetBytes(textSend.Text + "$"); 
      serverStream.Write(outStream, 0, outStream.Length); 
      serverStream.Flush(); 

      // Clear text 
      textSend.Text = ""; 

     } 

     private void textDisplay_TextChanged(object sender, EventArgs e) 
     { 
      textDisplay.SelectionStart = textDisplay.Text.Length; 
      textDisplay.ScrollToCaret(); 
      textDisplay.Refresh(); 
     } 

     private void textSend_TextChanged(object sender, EventArgs e) 
     { 
      buttonSend.Enabled = !string.IsNullOrEmpty(textSend.Text); 
     } 
    } 
} 
+1

Tenga en cuenta que el .NET Framework ha violado una de las Pautas de diseño de .NET Framework: que las clases con nombres generales deben ser clases de propósito general. Considera 'String' vs.' XmlTextReader'. 'Timer' es un nombre general, y una o ambas clases están especializadas. –

Respuesta

5

el problema es que usted está

using System.Windows.Forms; 
using System.Threading; 

Ambos de estos espacios de nombres tienen una clase Timer y el compilador no puede saber cuál usar. Cuando se declara su Timer, utilice el nombre completo, ya sea:

System.Windows.Forms.Timer 

o

System.Threading.Timer 

WinForms Timer Class

Threading Timer Class

en base al uso de la clase, yo creo que usted quiere System.Windows.Forms.Timer, como ese:

public SocketClient() 
    { 
     InitializeComponent(); 
     var timer = new System.Windows.Forms.Timer(); 
     timer.Tick += new EventHandler(TimerOnTick); 
     timer.Interval = 1000; 
     timer.Start(); 
    } 
29

Hay varias opciones aquí:

  • utilizar un alias:

    using UITimer = System.Windows.Forms.Timer; 
    
    ... 
    UITimer timer = new UITimer(); 
    
  • Usar el nombre completo:

    System.Windows.Forms.Timer timer = new System.Windows.Forms.Timer(); 
    
  • Usar un alias de espacio de nombres:

    using WinForms = System.Windows.Forms; 
    ... 
    WinForms::Timer timer = new WinForms::Timer(); 
    

Sin embargo, sugeriría personalmente división del código de la interfaz de usuario del código de red - y en ese momento es poco probable que sea un problema.

También me gustaría señalar que actualmente está leyendo de la transmisión sin tomar en cuenta el valor de retorno; esa es una mala idea, ya que no sabe qué cantidad de memoria intermedia realmente contiene datos nuevos.

+0

¡Olvidé por completo el aliasing, tonto! – Sapph

+0

¿por qué esta respuesta no es la respuesta aceptada? – Liban

Cuestiones relacionadas