Après C#2005, l'accès direct multithread aux contrôles d'interface n'est plus pris en charge (le thread de création d'interface et le thread d'accès ne sont pas le même thread), mais vous pouvez utiliser délégué pour résoudre le problème :
1. Déclarer un délégué et définir une fonction d'implémentation de délégué
view plaincopy to clipboardPRint?
delegate void ShowProgressDelegate(int newPos);
private void ShowProgress(int newPos) 🎜>if (!_progressBar.InvokeRequired )
{
// Sinon, faites fonctionner le contrôle directement
_progressBar.Value = newPos;
}
else
{
// Oui Si vous souhaitez activer le délégué access,
ShowProgressDelegate showProgress = new ShowProgressDelegate(ShowProgress);
// Si vous utilisez Invoke, vous attendrez la fin de l'appel de fonction, mais BeginInvoke n'attendra pas et reviendra directement
this.BeginInvoke(. showProgress, new object [] { newPos });
}
}
delegate void ShowProgressDelegate(int newPos);
private void ShowProgress(int newPos)
{
// Déterminer que ce soit dans le fil Access
if (!_progressBar.InvokeRequired)
{
// Sinon, actionner directement le contrôle
_progressBar.Value = newPos;
}
else
{
/ / Si oui, activez l'accès des délégués
ShowProgressDelegate showProgress = new ShowProgressDelegate(ShowProgress);
// Si vous utilisez Invoke, vous attendrez que l'appel de fonction soit terminé, mais BeginInvoke le fera n'attendez pas et revenez directement en arrière
this.BeginInvoke(showProgress, new object[] { newPos });
}
}
Définir la fonction du thread (les contrôles d'interface peuvent être lus dans un autre fil de discussion)
afficher la copie dans le presse-papiers ?
private void ProgressStart()
{
while (true)
{
int newPos = _progressBar.Value 10 ; newPos > _progressBar.Maximum)
newPos = _progressBar.Minimum;
}
Trace.WriteLine(string.Format("Pos: {0}", newPos)); est appelé directement ici et détermine automatiquement si le délégué est activé
ShowProgress(newPos);
Thread.Sleep(100); 🎜>{
int newPos = _progressBar.Value 10;
if (newPos); > _progressBar.Maximum)
{
newPos = _progressBar.Minimum;
>
Trace.WriteLine( string.Format("Pos: {0}", newPos));
/ / La méthode est appelée directement ici et elle détermine automatiquement s'il faut activer le délégué
ShowProgress(newPos);
Thread.Sleep(100 );
}
}
3. Démarrage et terminaison du fil
view plaincopy to clipboardprint?
private Thread _progressThread; ));
// Facultatif, fonction : même si le fil ne se termine pas, le processus peut se terminer
_progressThread.IsBackground = true;
_progressThread.Start();
_progressThread.Abort();
// Facultatif, fonction : attendez la fin du fil de discussion avant de continuer
_progressThread.Join(); null;
Ce qui précède est le contenu de l'interface d'accès multi-thread c#, plus connexe. Veuillez faire attention au site Web PHP chinois (m.sbmmt.com) pour le contenu !