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


    第一种:使用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)
    {
      // ....
    }

  • 相关阅读:
    Python DayDayUp系列 —— 字符串操作(一)
    Condition对象以及ArrayBlockingQueue阻塞队列的实现(使用Condition在队满时让生产者线程等待, 在队空时让消费者线程等待)
    ReadWriteLock: 读写锁
    优秀的github项目学习
    synchronized:内部锁
    ReentreantLock:重入锁
    好的文章
    Java内存模型与volatile关键字
    GitHub远程库的搭建以及使用
    使用Executor框架创建线程池
  • 原文地址:https://www.cnblogs.com/zwzw/p/2260777.html
Copyright © 2020-2023  润新知