2009-05-16 9 views
0

C# 2005Invocation Ausnahme mit Autoreset

ich einen Hintergrund Arbeiter bin mit etwas Login-Daten zu verarbeiten. Der Hintergrundarbeiter muss jedoch anhalten und auf 2 Ereignisse warten. Sobald diese beendet sind, kann der Hintergrundarbeiter seine Arbeit abschließen. Sie sind Callbacks, die die Set() -Methode von AutoResetEvent aufrufen.

Also verwende ich AutoResetEvent zu setzen, wenn diese 2 Ereignisse beendet sind. Jedoch schien ich diese Fehlermeldung zu erhalten: "Ausnahme wurde vom Ziel eines Aufrufs ausgelöst."

Und innere Ausnahme Index war außerhalb des Bereichs. Muss nicht negativ und kleiner als die Größe der Sammlung sein. Parametername:. Index“

Die Ausnahme löst in der Regel, wenn die Registrierung erfolgreich Umfang verlässt

Vielen Dank für jede Beratung

Der Code für den Hintergrund Arbeiter

// Waiting for 'Account in use' and 'Register success or failure' 
AutoResetEvent[] loginWaitEvents = new AutoResetEvent[] 
{ 
     new AutoResetEvent(false), 
     new AutoResetEvent(false) 
}; 

private void bgwProcessLogin_DoWork(object sender, DoWorkEventArgs e) 
{ 
     Console.WriteLine("Wait until event is set or timeout"); 
     loginWaitEvents[0].WaitOne(3000, true); 

     if (this.accountInUseFlag) 
     { 
       if (this.lblRegistering.InvokeRequired) 
       { 
        ///this.lblRegistering.Invoke(new UpdateRegisterLabelDelegate(this.UpdateRegisterLabel), "Account in use"); 
       } 
       else 
       { 
        ///this.lblRegistering.Text = "Account in use"; 
       } 
       // Failed attemp 
       e.Cancel = true; 
       // Reset flag 
       //this.accountInUseFlag = false; 
       return; 
     } 
     else 
     { 
       // Report current progress 
       //this.bgwProcessLogin.ReportProgress(7, "Account accepted"); 
     } 

     Console.WriteLine("Just Wait the result of successfull login or not"); 
     loginWaitEvents[1].WaitOne(); 
     Console.WriteLine("Results for login registionSuccess: [ " + registerSuccess + " ]"); 

     if (this.registerSuccess) 
     { 
       // Report current progress 
       //this.bgwProcessLogin.ReportProgress(7, "Register Succesfull"); 
       // Reset flag 
       //this.registerSuccess = false; 
     } 
     else 
     { 
       if (this.lblRegistering.InvokeRequired) 
       { 
        //this.lblRegistering.Invoke(new UpdateRegisterLabelDelegate(this.UpdateRegisterLabel), "Failed to register"); 
       } 
       else 
       { 
        // this.lblRegistering.Text = "Failed to register"; 
       } 
       // Failed attemp 
       e.Cancel = true;    
       return; 
     } 
} 

// Wait for the callback to set the AutoResetEvent 

// Error sometimes happens when the function leaves scope. 
private void VaxSIPUserAgentOCX_OnSuccessToRegister(object sender, EventArgs e) 
{ 
     Console.WriteLine("OnSuccessToRegister() [ Registered successfully ]"); 
     this.registerSuccess = true; 
     this.loginWaitEvents[1].Set(); 
} 


// If the flag is not set, then just time out after 3 seconds for the first LoginWaitEvent.waitOne(3000, true) 
private void VaxSIPUserAgentOCX_OnIncomingDiagnostic(object sender, AxVAXSIPUSERAGENTOCXLib._DVaxSIPUserAgentOCXEvents_OnIncomingDiagnosticEvent e) 
{ 
     string messageSip = e.msgSIP; 

     //Indicates that a user is already logged on (Accout in use). 
     string sipErrorCode = "600 User Found"; 
     if (messageSip.Contains(sipErrorCode)) 
     { 
      // Set flag for account in use 
      this.accountInUseFlag = true; 
      Console.WriteLine("OnIncomingDiagnostic() WaitEvent.Set() accountInUseFlag: " + this.accountInUseFlag); 
      loginWaitEvents[0].Set(); 
     } 
} 
+0

Was macht UpdateRegisterLabel? Stellt es nur den Text auf einem Label-Steuerelement ein? –

Antwort

1

Es ist.. höchstwahrscheinlich ein Indexierungsfehler in der UpdateRegisterLabel-Methode

Erhalten Sie eine Stack-Trace von der inneren Ausnahme, sollte es Sie mehr zeigen nah dran wo es ist.

+0

Hallo, ich habe mein Problem gelöst. Es war etwas im RunWorker abgeschlossen. Es gibt jedoch noch eine Sache. Die RegisterSuccess und AccountInUse sind global, da auf sie von 2 verschiedenen Threads zugegriffen wurde. Wäre es besser, sie zu sperren? Vielen Dank – ant2009

+0

Sie müssen Boole nicht sperren, aber Sie können sie als flüchtig markieren, um sicherzustellen, dass jeder Thread immer den aktuellsten Wert hat. –