使用ParameterizedThreadStart委托向线程函数传送参数「建议收藏」

使用ParameterizedThreadStart委托向线程函数传送参数「建议收藏」在不传递参数情况下,一般大家都使用ThreadStart代理来连接执行函数,ThreadStart委托接收的函数不能有参数,也不能有返回值。如果希望传递参数给执行函数,则可以使用带参数的ParameterizedThreadStart委托,     publicdelegatevoidParameterizedThreadStart(Objectobj)可以将要传送给

大家好,又见面了,我是你们的朋友全栈君。在不传递参数情况下,一般大家都使用ThreadStart代理来连接执行函数,ThreadStart委托接收的函数不能有参数,也不能有返回值。如果希望传递参数给执行函数,则可以使用带参数的ParameterizedThreadStart委托,

          public delegate void ParameterizedThreadStart(Object obj)

可以将要传送给线程函数的信息封装为一个对象,然后调用Thread类的以下构造函数

          public Thread (ParameterizedThreadStartstart)

启动线程时,向其传送一个参数信息

          Thread t = new Thread(new ParameterizedThreadStart(线程函数));
           t.Start(object nParam);

其中object nParam就是要传递的参数,之所以使用object类型,那是因为nParam可以是任何class类型,这样你就可传递任何类型给执行函数.

根据参数个数和返回值的不同又分为以下几种情形:

一.单参数、无返回值

这是最简单最直接的情形,无需做其他处理,直接传递

[csharp]

  1. using System;  
  2. using System.Collections.Generic;  
  3. using System.Text;  
  4. using System.Threading;  
  5.   
  6. namespace ThreadAbort  
  7. {  
  8.     class Program  
  9.     {  
  10.         static void Main(string[] args)  
  11.         {  
  12.             System.Console.WriteLine(“主线程开始”);  
  13.             //创建线程对象  
  14.             MyThread obj = new MyThread();  
  15.             Thread th = new Thread(new ParameterizedThreadStart(obj.SomeLongTask));  
  16.             th.IsBackground = true;  
  17.             th.Start(10);//启动线程,传递参数10  
  18.             th.Join();  
  19.             System.Console.WriteLine(“主线程结束”);  
  20.         }  
  21.     }  
  22.   
  23.     class MyThread  
  24.     {  
  25.         public void SomeLongTask(object obj)  
  26.         {  
  27.             int n = Convert.ToInt32(obj); //将接收的参数转换为需要的类型  
  28.             System.Console.WriteLine(“辅助线程开始…”);  
  29.             for (int i = 0; i <= n; i++)  
  30.             {  
  31.                 System.Console.WriteLine(i);  
  32.                 Thread.Sleep(100);  
  33.             }  
  34.         }  
  35.     }  
  36. }  

二.多参数、有返回值

需要创建一个参数辅助类用于传递参数和返回值,例如:


    class ThreadMethodHelper
    {

          //线程输入参数
          public intx;
          public inty;
          //函数返回值
          public long returnVaule;
    }


然后改造线程函数为ParameterizedThreadStart委托支持的形式


   public void SomeFunc(object argu)
   {

          long ret = 0;
          intx = (arguas ThreadMethodHelper).x;
          inty = (arguas ThreadMethodHelper).y;
          //使用x和y完成一些工作,结果保存在ret中
          (arguas ThreadMethodHelper).returnVaule= ret;
    }


最后就可以使用辅助类进行线程操作了


MyThreadobj= new MyThread();
varargu= new ThreadMethodHelper();


//设定线程函数参数
argu.x= 100; argu.y= 200;


//创建线程对象
Thread t = new Thread(new ParameterizedThreadStart(obj.SomeFunc));


//启动线程,向线程传送线程参数
t.Start(argu);


//主线程干其他事……
t.Join();//等待辅助线程结束


Console.WriteLine(argu.returnVaule); //取回线程结果

例1:

  1. using System;  
  2. using System.Collections.Generic;  
  3. using System.Text;  
  4. using System.Threading;  
  5.   
  6. namespace ThreadTest  
  7. {  
  8.     class ThreadMethodHelper  
  9.     {  
  10.         //线程输入参数  
  11.         public int x;  
  12.         public int y;  
  13.         //函数返回值  
  14.         public long returnVaule;  
  15.     }  
  16.     class MultiParas  
  17.     {  
  18.         public static void SomeTask(object argu)  
  19.         {  
  20.             long ret = 0;  
  21.             int x = (argu as ThreadMethodHelper).x;  
  22.             int y = (argu as ThreadMethodHelper).y;  
  23.             //使用x和y完成一些工作,结果保存在ret中  
  24.             ret = x * y;  
  25.             (argu as ThreadMethodHelper).returnVaule= ret;  
  26.         }  
  27.         static void Main(string[] args)  
  28.         {  
  29.             System.Console.WriteLine(“主线程开始”);  
  30.             ThreadMethodHelper arg = new ThreadMethodHelper{x = 10, y = 100};  
  31.             //创建线程对象  
  32.             Thread th = new Thread(new ParameterizedThreadStart(SomeTask));  
  33.             //Thread th = new Thread(SomeTask);//这样写也可以  
  34.             th.IsBackground = true;  
  35.             th.Start(arg);//启动线程,传递参数10  
  36.             th.Join();  
  37.             Console.WriteLine(“the result is :” + arg.returnVaule);  
  38.             System.Console.WriteLine(“主线程结束”);  
  39.         }  
  40.     }  
  41. }  

例2:

  1. using System;  
  2. using System.Collections.Generic;  
  3. using System.Text;  
  4. using System.Threading;  
  5.   
  6. namespace UseArray  
  7. {  
  8.     class Program  
  9.     {  
  10.         static void Main(string[] args)  
  11.         {  
  12.             Thread th = new Thread(DoWithArray);  
  13.             ThreadMethodHelper argu = new ThreadMethodHelper();  
  14.             argu.arr = new int[] { -1, 9, 100, 78, 23, 54, -90 };  
  15.             th.Start(argu);  
  16.             th.Join();  
  17.             Console.WriteLine(“数组元素清单”);  
  18.             foreach (int i in argu.arr)  
  19.             {  
  20.                 Console.Write(i.ToString() + ”  “);  
  21.             }  
  22.             Console.WriteLine();  
  23.             Console.WriteLine(“最大值:{0}”, argu.MaxValue);  
  24.             Console.WriteLine(“最小值:{0}”, argu.MinValue);  
  25.             Console.WriteLine(“总和:{0}”, argu.Sum );  
  26.             Console.WriteLine(“平均值:{0}”, argu.Average );  
  27.   
  28.             Console.ReadKey();  
  29.         }  
  30.   
  31.         static void DoWithArray(object  obj)  
  32.         {  
  33.             ThreadMethodHelper argu = obj as ThreadMethodHelper;  
  34.             for (int i = 0; i < argu.arr.Length; i++)  
  35.             {  
  36.                 if (argu.arr[i] > argu.MaxValue)  
  37.                     argu.MaxValue = argu.arr[i];  
  38.                 if (argu.arr[i] < argu.MinValue)  
  39.                     argu.MinValue = argu.arr[i];  
  40.                 argu.Sum += argu.arr[i];  
  41.             }  
  42.             argu.Average = argu.Sum / argu.arr.Length;  
  43.         }  
  44.     }  
  45.   
  46.     //封装线程的输入和输出信息  
  47.     class ThreadMethodHelper  
  48.     {  
  49.         //线程输入参数  
  50.         public int[] arr;  
  51.         //函数返回值  
  52.         public int MaxValue=0;  
  53.         public int MinValue=0;  
  54.         public long Sum=0;  
  55.         public double Average=0;  
  56.     }  
  57. }  

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请联系我们举报,一经查实,本站将立刻删除。

发布者:全栈程序员-站长,转载请注明出处:https://javaforall.net/159637.html原文链接:https://javaforall.net

(0)
上一篇 2022年7月15日 下午2:36
下一篇 2022年7月15日 下午2:46


相关推荐

  • 讯飞星火教案生成教程详解

    讯飞星火教案生成教程详解

    2026年3月14日
    1
  • FastCGI开发学习

    FastCGI开发学习http://www.xinze.me/fastcgi%E5%BC%80%E5%8F%91%E5%AD%A6%E4%B9%A0/1.下载fastcgi开发包,编译安装http://www.fastcgi.com/dist/fcgi-current.tar.gz1wgethttp://www.fastcgi.com/dist/fcgi-curren

    2022年7月11日
    24
  • goland激活码20213月最新在线激活

    goland激活码20213月最新在线激活,https://javaforall.net/100143.html。详细ieda激活码不妨到全栈程序员必看教程网一起来了解一下吧!

    2022年3月14日
    66
  • [java]根据ip和掩码计算网段、广播地址及可用ip地址范围

    [java]根据ip和掩码计算网段、广播地址及可用ip地址范围ip 地址与掩码 网段 广播地址 可用 ip 范围 IP 网络地址掩码 指明一个 IP 地址的哪些位标识的是主机所在的子网 网段 网络中可通信的部分 一般用子网第一个地址表示 广播地址 专门用于同时向网络中所有工作站进行发送的一个地址 一般用子网最后一个地址表示 可用子网 ip 一般指子网中去除网段 广播地址的地址范围参考资料 子网划分完整代码 importjava util HashMap publicclassI 在 main 方法里

    2026年3月26日
    2
  • jmeter并发测试教程_jmeter进行并发测试教程[通俗易懂]

    jmeter并发测试教程_jmeter进行并发测试教程[通俗易懂]jmeter是Apache组织开发的基于Java的压力测试工具,用于对软件做压力测试,很多用户使用的时候不知道jmeter怎么进行并发测试,接下来就跟小编一起来看看吧,有需要的小伙伴不要错过!jmeter怎么进行并发测试1、打开jmeter.bat文件,添加线程组,编辑线程数,这里设置100个线程数,循环2次,就是一台机器发送100*2=200个请求。2、点击线程组,右击添加→取样器→HTTP请求…

    2022年9月30日
    5
  • Protel99SE教程(一)——原理图封装

    Protel99SE教程(一)——原理图封装  今天我要讲解的是“如何在protel99se中创建一个原理图封装”,下面开始我们的操作:  第一步:新建“Schlib1.Lib”文件。  点击“File”下的“New”,弹出protel99se所能支持的所有文件格式,选中“SchematicLibraryDecument”,点击“OK”,新建“Schlib1.Lib”文件,如图1所示。图1 创建原理图…

    2022年5月30日
    38

发表回复

您的邮箱地址不会被公开。 必填项已用 * 标注

关注全栈程序员社区公众号