@Engram:
Vous avez obtenu l'essentiel de celui-ci - CrossThreadCalls sont juste une belle fonctionnalité MS mis dans le .NET Framework pour éviter le type « bonehead » d'erreurs de programmation parallèle. Il peut être remplacé, comme je suppose que vous l'avez déjà découvert, en définissant la propriété "AllowCrossThreadCalls" sur la classe (et non sur une instance de la classe, par exemple set Label.AllowCrossThreadCalls et non lblMyLabel.AllowCrossThreadCalls) .
Mais, plus important encore, vous avez raison d'utiliser un mécanisme de verrouillage. Chaque fois que vous avez plusieurs threads d'exécution (threads, processus ou autres), vous devez vous assurer que lorsque vous avez un thread lire/écrire dans une variable, vous ne voulez probablement pas d'autres threads et changer cette valeur sous les pieds du premier fil. Le .NET FRAMEWORK fournit en réalité plusieurs autres mécanismes qui pourraient être plus utiles, selon les circonstances, que le verrouillage du code. La première consiste à utiliser une classe Monitor, ce qui a pour effet de verrouiller un objet particulier. Lorsque vous utilisez cela, d'autres threads peuvent continuer à s'exécuter, tant qu'ils n'essaient pas de verrouiller le même objet. Une autre idée de programmation parallèle très utile et commune est la Mutex (ou Semaphore). Le Mutex est fondamentalement comme un jeu de Capture du drapeau entre vos discussions. Si un thread attrape le drapeau, aucun autre thread ne peut l'attraper avant que le premier thread ne le lâche. (Un Sémaphore est juste comme un Mutex, sauf qu'il peut y avoir plus d'un drapeau dans un jeu.)
Évidemment, aucun de ces concepts ne fonctionnera dans chaque problème particulier - mais avec quelques outils supplémentaires pour vous aider pourrait être utile un jour :)
Merci de votre contribution Mike. Très utile. – James