Maison développement back-end Tutoriel C#.Net Passage de paramètres multithread C#

Passage de paramètres multithread C#

Feb 17, 2017 am 10:51 AM

1. Passez par la classe d'entité (vous pouvez passer plusieurs paramètres et obtenir la valeur de retour), la démo est la suivante :

Fonction qui doit être appelée dans le fil :

namespace ThreadParameterDemo
{
    public class FunctionClass
    {
        public static string TestFunction(string name, int age)
        {
            //内部处理省略
            return name + " 的年龄是:" + age;
        }
    }
}
Copier après la connexion

Encapsulé à travers des entités :

namespace ThreadParameterDemo
{
    /// <summary>
    /// 过渡类
    /// </summary>
    public class TransitionalClass
    {
        private string name = string.Empty;
        private int age;
        public string acceptResults = string.Empty;
        public TransitionalClass(string name, int age)
        {
            this.name = name;
            this.age = age;
        }

        public void TestFunction()
        {
            acceptResults = FunctionClass.TestFunction(this.name, this.age);
        }
    }
}
Copier après la connexion

Appel :

  private void Form1_Load(object sender, EventArgs e)
        {
            //实例化ThreadWithState类,为线程提供参数  
            TransitionalClass tc = new TransitionalClass(" Jack", 42);
            // 创建执行任务的线程,并执行  
            Thread t = new Thread(new ThreadStart(tc.TestFunction));
            t.Start();
            //获取返回值,通过 tc.acceptResults;  
        }
Copier après la connexion


Petite note :

Vous devez faire attention au problème d'IsBackground Si IsBackground est faux, le programme Windows ne quittera pas automatiquement le fil de discussion pour vous. quand il sort. Autrement dit, votre candidature n’est pas réellement terminée.

Recommandation MSDN : La meilleure façon de fournir des paramètres pour les appels de méthode multithread est d'envelopper la méthode cible dans une classe et de donner la classe Définir les champs qui seront utilisés comme paramètres pour le nouveau thread.

L'avantage de cette approche est qu'à chaque fois que vous souhaitez démarrer un nouveau fil de discussion, vous pouvez créer une nouvelle instance de la classe, avec ses propres paramètres.

Classe BackgroundWorker

La fonction dans ThreadStart n'a pas de valeur de retour ni de paramètres

2. Paramètres et valeurs de retour dans les appels asynchrones
La solution parfaite pour les paramètres et les valeurs de retour consiste à utiliser des appels asynchrones. Par rapport à Thread, l’un des plus gros inconvénients des appels asynchrones est qu’ils ne peuvent pas contrôler leur priorité.

Le code spécifique est le suivant :

        public delegate string delegateFunction(string name,int age);//委托
        delegateFunction df;
        private void Form1_Load(object sender, EventArgs e)
        {
            //指向需要调用的方法
            df = new delegateFunction(FunctionClass.TestFunction);
            string name = "my name";//输入参数 
            int age = 19;
            IAsyncResult result = df.BeginInvoke(name,age, null, null);
            string myResult = df.EndInvoke(result);//用于接收返回值 
            MessageBox.Show(myResult);
        }
Copier après la connexion

Simplifié :

 public Func<string, int, string>  df;//委托
        private void Form1_Load(object sender, EventArgs e)
        {
            //指向需要调用的方法
            df += FunctionClass.TestFunction;
            string name = "my name";//输入参数 
            int age = 19;
            IAsyncResult result = df.BeginInvoke(name, age, null, null);
            string myResult = df.EndInvoke(result);//用于接收返回值 
            MessageBox.Show(myResult);
        }
Copier après la connexion

Petite note :

Dans See More de cette façon Le nouveau thread généré s'exécute en arrière-plan (arrière-plan), et la priorité est normale


3 . Utilisez BackgroundWorker

Le moyen le plus simple de renvoyer une valeur à partir de plusieurs threads consiste à utiliser le composant BackgroundWorker pour gérer les threads, à déclencher un événement lorsque la tâche est terminée, puis à utiliser un gestionnaire d'événements. pour gérer le résultat.

Petite remarque :
Le composant BackgroundWorker est utilisé pour effectuer des opérations asynchrones fastidieuses telles que des transactions de base de données et des téléchargements de fichiers.
Ajoutez une instance BackgroundWorker dans l'application. Si vous utilisez VS, vous pouvez la faire glisser directement de l'outil vers l'application :

BackgroundWorker backgroundWorker1 = new BackgroundWorker();
Copier après la connexion

Pour commencer à fonctionner en arrière-plan, vous devez appeler la méthode RunWorkerAsync() de BackgroundWorker. Lorsque cette méthode est appelée, BackgroundWorker commence à effectuer des opérations en arrière-plan en déclenchant l'événement DoWork. exécuté dans un autre thread.
Lorsque l'opération en arrière-plan est terminée, qu'elle soit terminée ou annulée, l'événement RunWorkerCompleted est déclenché. Grâce à cette méthode, le résultat de l'achèvement de l'opération en arrière-plan peut être renvoyé à l'utilisateur.
De plus, utilisez la propriété Canceled de l'instance RunWorkerCompletedEventArgs pour déterminer si l'opération en arrière-plan est terminée en raison de l'opération Cancel.


La démo spécifique est la suivante :


using System;
using System.Windows.Forms;

namespace WindowsFormsApplication1
{
    public partial class Form2 : Form
    {
        public Form2()
        {
            InitializeComponent();
        }

        private void Form2_Load(object sender, EventArgs e)
        {
            //TransitionalClass tc = new TransitionalClass("xiaoming", 10);
            //ThreadPool.QueueUserWorkItem(new WaitCallback(TransitionalClass.TestFunction), tc);
        }

        private void button1_Click(object sender, EventArgs e)
        {
            this.TestArea2();
        }

        private System.ComponentModel.BackgroundWorker BackgroundWorker1
    = new System.ComponentModel.BackgroundWorker();

        private void TestArea2()
        {
            InitializeBackgroundWorker();

            AreaClass2 AreaObject2 = new AreaClass2();
            AreaObject2.Base = 30;
            AreaObject2.Height = 40;

            // Start the asynchronous operation.
            BackgroundWorker1.RunWorkerAsync(AreaObject2);
        }

        private void InitializeBackgroundWorker()
        {
            // Attach event handlers to the BackgroundWorker object.
            BackgroundWorker1.DoWork +=
                new System.ComponentModel.DoWorkEventHandler(BackgroundWorker1_DoWork);
            BackgroundWorker1.RunWorkerCompleted +=
                new System.ComponentModel.RunWorkerCompletedEventHandler(BackgroundWorker1_RunWorkerCompleted);
        }

        private void BackgroundWorker1_DoWork(
            object sender,
            System.ComponentModel.DoWorkEventArgs e)
        {
          //在执行DoWork 事件时,DoWorkEventArgs 实例的Result 属性,返回值到用户;在RunWorkerCompleted 事件里,RunWorkerCompletedEventArgs 实例的Result 属性接收值;
            AreaClass2 AreaObject2 = (AreaClass2)e.Argument;
            // Return the value through the Result property.
            e.Result = AreaObject2.CalcArea();
        }

        private void BackgroundWorker1_RunWorkerCompleted(
            object sender,
            System.ComponentModel.RunWorkerCompletedEventArgs e)
        {
            // Access the result through the Result property. 
            double Area = (double)e.Result;
            MessageBox.Show("The area is: " + Area.ToString());
        }
    }
}
Copier après la connexion


Code de démonstration de MSDN : Cliquez pour ouvrir le lien


Article de référence : Cliquez pour ouvrir le lien

4 . Si ce n'est pas aussi bon que la valeur de retour, comment devrions-nous l'écrire avec élégance ? Fonction anonyme Passage de paramètres multithread C#

La classe FunctionClass est ajoutée, la fonction de test est la suivante :

   public static void TestFunction2(string name, int age)
        {
            //内部处理省略            
        }
Copier après la connexion

L'appel est le suivant :

 private void Form1_Load(object sender, EventArgs e)
        {
            Thread t1 = new Thread(new ThreadStart(delegate
            {
                FunctionClass.TestFunction2("eee", 5);
            }));
            t1.Start();          
        }
Copier après la connexion

Petite note :

Si elle est appelée via WCF, la fonction de démarrage du thread doit être placée sur le serveur. Si elle est placée sur le client, il est facile de provoquer un crash inexplicable du programme principal en raison de la limite de temps. Client WCF.

La principale raison du crash est que le temps de réponse du client WCF est limité.

Ce qui précède est le contenu du passage des paramètres multithread C#. Pour plus de contenu connexe, veuillez faire attention au site Web PHP chinois (www.php.cn) !


Déclaration de ce site Web
Le contenu de cet article est volontairement contribué par les internautes et les droits d'auteur appartiennent à l'auteur original. Ce site n'assume aucune responsabilité légale correspondante. Si vous trouvez un contenu suspecté de plagiat ou de contrefaçon, veuillez contacter admin@php.cn

Outils d'IA chauds

Undresser.AI Undress

Undresser.AI Undress

Application basée sur l'IA pour créer des photos de nu réalistes

AI Clothes Remover

AI Clothes Remover

Outil d'IA en ligne pour supprimer les vêtements des photos.

Undress AI Tool

Undress AI Tool

Images de déshabillage gratuites

Clothoff.io

Clothoff.io

Dissolvant de vêtements AI

AI Hentai Generator

AI Hentai Generator

Générez AI Hentai gratuitement.

Article chaud

R.E.P.O. Crystals d'énergie expliqués et ce qu'ils font (cristal jaune)
4 Il y a quelques semaines By 尊渡假赌尊渡假赌尊渡假赌
R.E.P.O. Meilleurs paramètres graphiques
4 Il y a quelques semaines By 尊渡假赌尊渡假赌尊渡假赌
R.E.P.O. Comment réparer l'audio si vous n'entendez personne
1 Il y a quelques mois By 尊渡假赌尊渡假赌尊渡假赌
R.E.P.O. Commandes de chat et comment les utiliser
1 Il y a quelques mois By 尊渡假赌尊渡假赌尊渡假赌

Outils chauds

Bloc-notes++7.3.1

Bloc-notes++7.3.1

Éditeur de code facile à utiliser et gratuit

SublimeText3 version chinoise

SublimeText3 version chinoise

Version chinoise, très simple à utiliser

Envoyer Studio 13.0.1

Envoyer Studio 13.0.1

Puissant environnement de développement intégré PHP

Dreamweaver CS6

Dreamweaver CS6

Outils de développement Web visuel

SublimeText3 version Mac

SublimeText3 version Mac

Logiciel d'édition de code au niveau de Dieu (SublimeText3)

Active Directory avec C# Active Directory avec C# Sep 03, 2024 pm 03:33 PM

Guide d'Active Directory avec C#. Nous discutons ici de l'introduction et du fonctionnement d'Active Directory en C# ainsi que de la syntaxe et de l'exemple.

Sérialisation C# Sérialisation C# Sep 03, 2024 pm 03:30 PM

Guide de sérialisation C#. Nous discutons ici de l'introduction, des étapes de l'objet de sérialisation C#, du fonctionnement et de l'exemple respectivement.

Générateur de nombres aléatoires en C# Générateur de nombres aléatoires en C# Sep 03, 2024 pm 03:34 PM

Guide du générateur de nombres aléatoires en C#. Nous discutons ici du fonctionnement du générateur de nombres aléatoires, du concept de nombres pseudo-aléatoires et sécurisés.

Vue Grille de données C# Vue Grille de données C# Sep 03, 2024 pm 03:32 PM

Guide de la vue Grille de données C#. Nous discutons ici des exemples de la façon dont une vue de grille de données peut être chargée et exportée à partir de la base de données SQL ou d'un fichier Excel.

Modèles en C# Modèles en C# Sep 03, 2024 pm 03:33 PM

Guide des modèles en C#. Nous discutons ici de l'introduction et des 3 principaux types de modèles en C# ainsi que de ses exemples et de l'implémentation du code.

Nombres premiers en C# Nombres premiers en C# Sep 03, 2024 pm 03:35 PM

Guide des nombres premiers en C#. Nous discutons ici de l'introduction et des exemples de nombres premiers en c# ainsi que de l'implémentation du code.

Factorielle en C# Factorielle en C# Sep 03, 2024 pm 03:34 PM

Guide de Factorial en C#. Nous discutons ici de l'introduction de factorial en c# ainsi que de différents exemples et de l'implémentation du code.

La différence entre le multithreading et le C # asynchrone La différence entre le multithreading et le C # asynchrone Apr 03, 2025 pm 02:57 PM

La différence entre le multithreading et l'asynchrone est que le multithreading exécute plusieurs threads en même temps, tandis que les opérations effectuent de manière asynchrone sans bloquer le thread actuel. Le multithreading est utilisé pour les tâches à forte intensité de calcul, tandis que de manière asynchrone est utilisée pour l'interaction utilisateur. L'avantage du multi-threading est d'améliorer les performances informatiques, tandis que l'avantage des asynchrones est de ne pas bloquer les threads d'interface utilisateur. Le choix du multithreading ou asynchrone dépend de la nature de la tâche: les tâches à forte intensité de calcul utilisent le multithreading, les tâches qui interagissent avec les ressources externes et doivent maintenir la réactivité de l'interface utilisateur à utiliser asynchrone.

See all articles