C#线程调用带参数的方法 ~

    技术2022-05-11  41

    在 .NET Framework 2.0 版中,要实现线程调用带参数的方法有两种办法。第一种:使用ParameterizedThreadStart。调用 System.Threading.Thread.Start(System.Object) 重载方法时将包含数据的对象传递给线程。使用 ParameterizedThreadStart 委托不是传递数据的类型安全的方法,因为 System.Threading.Thread.Start(System.Object) 方法重载接受任何对象。这种方法不推荐使用,故在此不做详细介绍,具体用法参见:http://msdn2.microsoft.com/zh-cn/library/system.threading.parameterizedthreadstart(VS.80).aspx

    ParameterizedThreadStart ParStart  =   new  ParameterizedThreadStart(ThreadMethod);Thread myThread  =   new  Thread(ParStart); object  o  =   " hello " ;myThread.Start(o); // ThreadMethod如下: public   void  ThreadMethod( object  ParObject){     // 程序代码 }

    第二种:将线程执行的方法和参数都封装到一个类里面。通过实例化该类,方法就可以调用属性来实现间接的类型安全地传递参数。具体代码如下(本示例来自MSDN)

    using  System; using  System.Threading; // ThreadWithState 类里包含了将要执行的任务以及执行任务的方法 public   class  ThreadWithState {     // 要用到的属性,也就是我们要传递的参数      private   string  boilerplate;     private   int  value;     // 包含参数的构造函数      public  ThreadWithState( string  text,  int  number)     {        boilerplate  =  text;        value  =  number;    }     // 要丢给线程执行的方法,本处无返回类型就是为了能让ThreadStart来调用      public   void  ThreadProc()     {         // 这里就是要执行的任务,本处只显示一下传入的参数          Console.WriteLine(boilerplate, value);     }} // 用来调用上面方法的类,是本例执行的入口 public   class  Example {     public   static   void  Main()     {         // 实例化ThreadWithState类,为线程提供参数         ThreadWithState tws  =   new  ThreadWithState(             " This report displays the number {0}. " 42 );         //  创建执行任务的线程,并执行         Thread t  =   new  Thread( new  ThreadStart(tws.ThreadProc));        t.Start();        Console.WriteLine( " Main thread does some work, then waits. " );        t.Join();        Console.WriteLine(             " Independent task has completed; main thread ends. " );      }}

     

    ============================================================================

    方法一:在VS2003中,也不能直接访问,参看  一般来说,直接在子线程中对窗体上的控件操作是会出现异常,这是由于子线程和运行窗体的线程是不同的空间,因此想要在子线程来操作窗体上的控件,是不可能 简单的通过控件对象名来操作,但不是说不能进行操作,微软提供了Invoke的方法,其作用就是让子线程告诉窗体线程来完成相应的控件操作。  

    现在用一个用线程控制的进程条来说明,大致的步骤如下:  

    1.创建Invoke函数,大致如下:  /// <summary>  /// Delegate function be invoked by main thread  /// </summary>  private     void     InvokeFun()  {      if(prgBar.Value< 100)      prgBar.Value = prgBar.Value + 1;  }  

    2.子线程入口函数:  /// <summary>  /// Thread function interface  /// </summary>  private void ThreadFun()  {      // Create invoke method by specific function    MethodInvoker mi = new MethodInvoker(this.InvokeFun);  

        for(int i=0; i<100; i++)      {        this.BeginInvoke(mi);          Thread.Sleep(100);      }  }

    3.创建子线程:  Thread thdProcess = new Thread(new ThreadStart(ThreadFun));  thdProcess.Start();  

    备注:      using System.Threading;      private System.Windows.Forms.ProgressBar prgBar;  

    方法二:加入该句:Control.CheckForIllegalCrossThreadCalls = False    取消线线程安全保护模式!

    方法三:带参数使用类、类的方法或类的属性都可以向线程传递参数:public class UrlDownloader{    string url;      public UrlDownloader (string url)    {      this.url = url;    }      public void Download()    {      WebClient wc = new WebClient();      Console.WriteLine("Downloading " + url);                              byte[] buffer = wc.DownloadData (url);      string download = Encoding.ASCII.GetString(buffer);      Console.WriteLine(download);      Console.WriteLine("Download successful.");          //这里你可以将download进行保存等处理......    }}

    [... 在另一个类中使用它们...]              UrlDownloader downloader = new UrlDownloader (yourUrl);new Thread (new ThreadStart (downloader.Download)).Start();

    注意参数是如何传递的。

    方法四:带参数ThreadStart starter = delegate { Download(yourUrl); };new Thread(starter).Start();//使用线程池WaitCallback callback = delegate (object state) { Download ((string)state); };ThreadPool.QueueUserWorkItem (callback, yourUrl);

    方法五:带参数Thread t = new Thread (new ParameterizedThreadStart(DownloadUrl));t.Start (myUrl);static void DownloadUrl(object url){  // ....}

     


    最新回复(0)