zoukankan      html  css  js  c++  java
  • C#中 ThreadStart和ParameterizedThreadStart区别

    最主要区别:

    1.Thread 是启动一个线程,但是没有参数。

    2.ParameterThreadStart  线程可以接受一个输入参数

    ThreadStart:

    ThreadStart这个委托定义为void ThreadStart(),也就是说,所执行的方法不能有参数。

    ThreadStart threadStart=new ThreadStart(ProcessData);
    Thread thread=new Thread(threadStart);
    thread.Start();
    public void SayHelloToXiaohouye()
       {
    string strName="My name is Xiaohouye"; 
     Console.Write("Hello "+strName); }

         上面很简单的例子,我们用定义了一个ThreadStart类型的委托,这个委托制定了线程需要执行的方法: SayHelloToXiaohouye,在这个方法里声明一个变量,并输出.这就构成了最简单的多线程的例子,一般情况下,我们都是用这个的。

    ParameterThreadStart:

    ParameterThreadStart的定义为void ParameterizedThreadStart(object state),使用这个这个委托定义的线程的启动函数可以接受一个输入参数,具体例子如下 :

    ParameterizedThreadStart threadStart=new ParameterizedThreadStart(SayHelloToXiaohouye)
    Thread thread=new Thread() ;
    thread.Start("Xiaohouye");
    //注意参数一定要用object 类型,否则报错 public void SayHelloToXiaohouye(object name) {
    //使用时候需要转换 Console.Write("Hello my name is {0}",name.ToString()); }

    看了一个参数的例子,下面我们来看下多个参数的例子

    ,我们通过把多个参数组合到一个类中,然后把这个类的实例作为参数传递,就可以实现多个参数传递,废话不多说,看代码:

    public class AddParameter
    {
        public string a=string.Empty;
    public string b=string.Empty; public AddParameter(string name1, string name2) { a = name1; b = name2; } } #endregion class Program { static void Main(string[] args) { Console.WriteLine("***** Adding with Thread objects *****"); Console.WriteLine("当前线程为:{0}", Thread.CurrentThread.ManagedThreadId); AddParameter p = new AddParameter("xiaohouye", "xiaowangzi"); Thread t = new Thread(new ParameterizedThreadStart(Add)); t.Start(p); Console.ReadLine(); } #region Add method
    //组合参数 static void Add(object data) { if (data is AddParams) { Console.WriteLine("当前线程为:{0}",Thread.CurrentThread.ManagedThreadId); AddParameter ap = (AddParameter )data; Console.WriteLine("{0} + {1} is {2}", ap.a, ap.b, ap.a + ap.b); } } #endregion } }
  • 相关阅读:
    Spring Boot+Vue 项目前端_Vuejs环境搭建
    vue+element 数据表格分页
    vue+elementui 实现新增和修改共用一个弹框
    Vue删除数据成功后如何刷新表格数据
    vue中使用echart绑定点击事件进行路由切换
    Vue的生命周期
    添加访问量插件
    Docker部署的Gitlab平行迁移到另一台服务器上
    GLEAN: Generative Latent Bank for Large-Factor Image Super-Resolution【阅读笔记】
    Learning Continuous Image Representation with Local Implicit Image Function【阅读笔记】
  • 原文地址:https://www.cnblogs.com/zxtceq/p/7767366.html
Copyright © 2011-2022 走看看