Veröffentlicht 19. März 200916 j Hey, haben hier ein kleines Problem mit unserem Timer.... Das Problem ist, dass er nicht tickt und dementsprechend nicht den Registry Key überprüft. using System; using System.Collections.Generic; using System.Linq; using System.Text; using System.Windows.Forms; using System.IO; using System.Security.Permissions; using Microsoft.Win32; namespace afag { class Program { public RegistryKey rk; static void Main(string[] args) { Program a1 = new Program(); a1.rk = Registry.CurrentUser.OpenSubKey(@"[HKEY_LOCAL_MACHINE\System\CurrentControlSet\Services\EloUsb\Enum]"); Timer devTimer = new Timer(); devTimer.Interval = 3000; devTimer.Start(); devTimer.Tick += new EventHandler(a1.devTimer_Tick); Console.ReadKey(); } public void devTimer_Tick(object sender, EventArgs e) { string value = rk.GetValue("0").ToString(); if (value.EndsWith("50U00000")) { Console.WriteLine("Seriennummer des Elo-Controllers nicht programmiert!"); } } } } Danke schonmal im Vorraus:p
19. März 200916 j Du verwendest die Timer-Klasse aus System.Windows.Forms. Diese ist für die Verwendung mit einem Fenster vorgesehen und verwendet den GUI-Thread. Verwender eine der anderen Timer-Klassen.
20. März 200916 j System.Threading.Timer: ... // waits first time waitMSec and ticks every tickMSec after this yourTimer = new Timer(new TimerCallback(yourDelegate), yourParam, waitMSec, tickMSec); ... public (static) void yourDelegate(Object param) // param <= yourParam { if ( anyStateYouWant ) m_timer.Dispose(); // to destroy do with your param in any tick not } Bearbeitet 20. März 200916 j von VaNaTiC
20. März 200916 j Und es wäre wesentlich besser später noch eine Referenz zu dem Timer zu haben um ihn wieder stoppen zu können, also solltest du ihn als Member deiner Klasse definieren. Du solltest auch das Event binden bevor du den Timer startest.
Archiv
Dieses Thema wurde archiviert und kann nicht mehr beantwortet werden.