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

简介: 在 .NET Framework 2.0 版中,要实现线程调用带参数的方法有两种办法。第一种:使用ParameterizedThreadStart。 调用 System.Threading.Thread.Start(System.Object) 重载方法时将包含数据的对象传递给线程。

在 .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)
{
  // ....
}


转自 http://www.cnblogs.com/zyh-nhy/archive/2009/01/07/1371249.html

目录
相关文章
|
29天前
|
Java
线程池七大参数
核心线程数:线程池中的基本线程数量 最大线程数:当阻塞队列满了之后,逐一启动 最大线程的存活时间:当阻塞队列的任务执行完后,最大线长的回收时间 最大线程的存活时间单位 阻塞队列:当核心线程满后,后面来的任务都进入阻塞队列 线程工厂:用于生产线程
|
1月前
|
JSON 程序员 C#
使用 C# 比较两个对象是否相等的7个方法总结
比较对象是编程中的一项基本技能,在实际业务中经常碰到,比如在ERP系统中,企业的信息非常重要,每一次更新,都需要比较记录更新前后企业的信息,直接比较通常只能告诉我们它们是否指向同一个内存地址,那我们应该怎么办呢?分享 7 个方法给你!
|
1月前
|
C# UED SEO
C# 异步方法async / await任务超时处理
通过使用 `Task.WhenAny`和 `Task.Delay`方法,您可以在C#中有效地实现异步任务的超时处理机制。这种方法允许您在指定时间内等待任务完成,并在任务超时时采取适当的措施,如抛出异常或执行备用操作。希望本文提供的详细解释和代码示例能帮助您在实际项目中更好地处理异步任务超时问题,提升应用程序的可靠性和用户体验。
69 3
|
2月前
|
Java 开发者
在Java多线程编程中,创建线程的方法有两种:继承Thread类和实现Runnable接口
【10月更文挑战第20天】在Java多线程编程中,创建线程的方法有两种:继承Thread类和实现Runnable接口。本文揭示了这两种方式的微妙差异和潜在陷阱,帮助你更好地理解和选择适合项目需求的线程创建方式。
27 3
|
2月前
|
Java 开发者
在Java多线程编程中,选择合适的线程创建方法至关重要
【10月更文挑战第20天】在Java多线程编程中,选择合适的线程创建方法至关重要。本文通过案例分析,探讨了继承Thread类和实现Runnable接口两种方法的优缺点及适用场景,帮助开发者做出明智的选择。
23 2
|
2月前
|
安全 Java
Java多线程通信新解:本文通过生产者-消费者模型案例,深入解析wait()、notify()、notifyAll()方法的实用技巧
【10月更文挑战第20天】Java多线程通信新解:本文通过生产者-消费者模型案例,深入解析wait()、notify()、notifyAll()方法的实用技巧,包括避免在循环外调用wait()、优先使用notifyAll()、确保线程安全及处理InterruptedException等,帮助读者更好地掌握这些方法的应用。
24 1
|
2月前
|
Java 开发者
Java多线程初学者指南:介绍通过继承Thread类与实现Runnable接口两种方式创建线程的方法及其优缺点
【10月更文挑战第20天】Java多线程初学者指南:介绍通过继承Thread类与实现Runnable接口两种方式创建线程的方法及其优缺点,重点解析为何实现Runnable接口更具灵活性、资源共享及易于管理的优势。
44 1
|
2月前
|
Java
在Java多线程编程中,`wait()`和`notify()`方法的相遇如同一场奇妙的邂逅
在Java多线程编程中,`wait()`和`notify()`方法的相遇如同一场奇妙的邂逅。它们用于线程间通信,使线程能够协作完成任务。通过这些方法,生产者和消费者线程可以高效地管理共享资源,确保程序的有序运行。正确使用这些方法需要遵循同步规则,避免虚假唤醒等问题。示例代码展示了如何在生产者-消费者模型中使用`wait()`和`notify()`。
32 1
|
1月前
|
C# 开发者
C# 一分钟浅谈:Code Contracts 与契约编程
【10月更文挑战第26天】本文介绍了 C# 中的 Code Contracts,这是一个强大的工具,用于通过契约编程增强代码的健壮性和可维护性。文章从基本概念入手,详细讲解了前置条件、后置条件和对象不变量的使用方法,并通过具体代码示例进行了说明。同时,文章还探讨了常见的问题和易错点,如忘记启用静态检查、过度依赖契约和性能影响,并提供了相应的解决建议。希望读者能通过本文更好地理解和应用 Code Contracts。
35 3
|
1月前
|
设计模式 C# 图形学
Unity 游戏引擎 C# 编程:一分钟浅谈
本文介绍了在 Unity 游戏开发中使用 C# 的基础知识和常见问题。从 `MonoBehavior` 类的基础用法,到变量和属性的管理,再到空引用异常、资源管理和性能优化等常见问题的解决方法。文章还探讨了单例模式、事件系统和数据持久化等高级话题,旨在帮助开发者避免常见错误,提升游戏开发效率。
51 4