先看微软如何给出的方法使用,如下查看,我们发现,如下两个委托,分别对应带参数创建线程 和 不带参数创建线程。


下列 委托 方法不带参数 ThreadStart

namespace System.Threading
{
// 摘要:
// 表示在 System.Threading.Thread 上执行的方法。
[ComVisible(true)]
public delegate void ThreadStart();
}
 
//ParameterizedThreadStart 带参数,参数为 object 类型,这就要求我们写的 函数(被委托的),输入参数是object
namespace System.Threading
{
// 摘要:
// 表示在 System.Threading.Thread 上执行的方法。
//
// 参数:
// obj:
// 包含该线程过程的数据的对象。
[ComVisible(false)]
public delegate void ParameterizedThreadStart(object obj);
}
 

如下,我们可以先定义一个简单的ShowMessage()方法,不带参数。
{

    public class Message

    {

        public void ShowMessage()

        {

            string message = string.Format("Async threadId is :{0}",

                                            Thread.CurrentThread.ManagedThreadId);

            Console.WriteLine(message);

            for (int n = ; n < ; n++)

            {

                Thread.Sleep();

                Console.WriteLine("The number is:" + n.ToString());

                Console.WriteLine("OK!");

            }

        }

    }

//主函数调用时

class Program

    {

        static void Main(string[] args)

        {

            Console.WriteLine("Main threadId is:" +

                              Thread.CurrentThread.ManagedThreadId);

            Message message = new Message();

            //Thread thread = new Thread(message.ShowMessage);              //委托绑定 ShowMessage()方法, 下列是通过 ThreadStart 委托绑定, 为什么这么写,后面有介绍

            Thread thread = new Thread(new ThreadStart(message.ShowMessage));  //通过ThreadStart委托绑定Message对象的ShowMessage()方法,该句

            thread.Start();                  //Start() 启动的线程默认在前台执行

                    //thread.IsBackground = true;         //将线程放到后台,这时应用程序域将在主线程完成时就被卸载,而不会等待异步线程的运行
Console.WriteLine("Do something ..........!"); Console.WriteLine("Main thread working is complete!"); } } }

同样我们可以利用 ParameterizedThreadStart 创建带参数的线程。
public class Person

    {

        public string Name

        {

            get;

            set;

        }

        public int Age

        {

            get;

            set;

        }

    }

    public class Message

    {

        public void ShowMessage(object person)

        {

            if (person != null)

            {

                Person _person = (Person)person;

                string message = string.Format("\n{0}'s age is {1}!\nAsync threadId is:{2}",

                    _person.Name, _person.Age, Thread.CurrentThread.ManagedThreadId);

                Console.WriteLine(message);

            }

            for (int n = ; n < ; n++)

            {

                Thread.Sleep();

                Console.WriteLine("The number is:" + n.ToString());

            }

        }

    }

    class Program

    {

        static void Main(string[] args)

        {

            Console.WriteLine("Main threadId is:" + Thread.CurrentThread.ManagedThreadId);

            Message message = new Message();

            //绑定带参数的异步方法

            Thread thread = new Thread(new ParameterizedThreadStart(message.ShowMessage));

            //Thread thread2 = new Thread((message.ShowMessage));

            Person person = new Person();

            person.Name = "Jack";

            person.Age = ;

            thread.Start(person);  //启动异步线程 

            Console.WriteLine("Do something ..........!");

            Console.WriteLine("Main thread working is complete!");

                     //Thread.Sleep(100000);
thread.Join();
} }

 

如上的都能实现如下图的结果:

添加,Thread.Sleep(5000);此时应用程序域将在主线程运行5秒后自动结束

为什么我们可以用 Thread()直接调用方法呢,我们按F12查看 Thread() 微软给出的定义。

如下,Thread 的方法重载,就是调用的 有参数的 和 无参数的 委托

谢谢阅读!分享共进步!

多线程之 ThreadStart 和 ParameterizedThreadStart 委托的更多相关文章

  1. C# 多线程编程 ThreadStart ParameterizedThreadStart

    原文地址:http://club.topsage.com/thread-657023-1-1.html 在实例化Thread的实例,需要提供一个委托,在实例化这个委托时所用到的参数是线程将来启动时要运 ...

  2. ThreadStart和ParameterizedThreadStart区别

    ThreadStart: ThreadStart这个委托定义为void ThreadStart(),也就是说,所执行的方法不能有参数. ThreadStart threadStart=new Thre ...

  3. C# ThreadStart和ParameterizedThreadStart区别

    ThreadStart: ThreadStart这个委托定义为void ThreadStart(),也就是说,所执行的方法不能有参数.ThreadStart threadStart=new Threa ...

  4. C#中 ThreadStart和ParameterizedThreadStart区别

    最主要区别: 1.Thread 是启动一个线程,但是没有参数. 2.ParameterThreadStart  线程可以接受一个输入参数 ThreadStart: ThreadStart这个委托定义为 ...

  5. C# 最基本的涉及模式(单例模式) C#种死锁:事务(进程 ID 112)与另一个进程被死锁在 锁 | 通信缓冲区 资源上,并且已被选作死锁牺牲品。请重新运行该事务,解决方案: C#关闭应用程序时如何关闭子线程 C#中 ThreadStart和ParameterizedThreadStart区别

    C# 最基本的涉及模式(单例模式) //密封,保证不能继承 public sealed class Xiaohouye    { //私有的构造函数,保证外部不能实例化        private  ...

  6. ThreadStart 与ParameterizedThreadStart的区别

    1) ParameterizedThreadStart与ThreadStart 1 static void Main(string[] args) { #region ParameterizedThr ...

  7. 那些年我们一起追逐的多线程(Thread、ThreadPool、委托异步调用、Task/TaskFactory、Parallerl、async和await)

    一. 背景 在刚接触开发的头几年里,说实话,根本不考虑多线程的这个问题,貌似那时候脑子里也有没有多线程的这个概念,所有的业务都是一个线程来处理,不考虑性能问题,当然也没有考虑多线程操作一条记录存在的并 ...

  8. C#多线程之基础篇1

    在多线程这一系列文章中,我们将讲述C#语言中多线程的相关知识,在多线程(基础篇)中我们将学习以下知识点: 创建线程 中止线程 线程等待 终止线程 确定线程的状态 线程优先级 前台线程和后台线程 向线程 ...

  9. 快速入门系列--CLR--02多线程

    最近,由于基础框架的整体升级,因此需要更新所有相关项目的DLL文件.这个过程存在不小的风险,因此也对发布后的生产服务器进行了密切的监控,结果还是出现了个别应用出现异常的情况,很快的占用了大量的服务器内 ...

随机推荐

  1. SUSE Linux忘记root密码的对策

    1)开机,进入GRUB界面: 此时有两个选择: SUSE LINUX ENTERPISE SERVER 10 SUSE LINUX ENTERPISE SERVER 10 (Failsafe) 移动光 ...

  2. ExtJS4.1 ExtJS TabPanel 双击标签关闭该页

    /*总觉得 TabPanel 生成的那个关闭按钮太小关闭的时候不太顺手 感觉不方便 所以想双击关闭tab方便些于是在网上找到下面的代码 URL:http://atian25.iteye.com/blo ...

  3. Druid 配置_配置WebStatFilter

    https://github.com/alibaba/druid/wiki/%E9%85%8D%E7%BD%AE_%E9%85%8D%E7%BD%AEWebStatFilter WebStatFilt ...

  4. 安装VS组件提示“所选驱动不再有效。继续安装之前,请先检查安装路径的设置。”要怎么办?

    电脑里面原来装了VS2010,包括的组件有VB和C++,现在想添加C#,结果安装的时候就提示“所选驱动不再有效.继续安装之前,请先检查安装路径的设置”,安装路径在C盘,还有40个G,不知道该怎么办? ...

  5. BusyBox 简化嵌入式 Linux 系统

    BusyBox 是很多标准 Linux® 工具的一个单个可执行实现.BusyBox 包含了一些简单的工具,例如 cat 和 echo,还包含了一些更大.更复杂的工具,例如 grep.find.moun ...

  6. google支付回调验证

    原文链接: https://my.oschina.net/lemonzone2010/blog/398736 Google支付问题 20150218,挂机的日本服务器出现google支付被刷单现象,虽 ...

  7. [翻译] SFRoundProgressCounterView 带有进度显示的倒计时视图

    SFRoundProgressCounterView 带有进度显示的倒计时视图 https://github.com/simpliflow/SFRoundProgressCounterView A c ...

  8. Combogrid的onChange和onSelect

    这里只作记录一下 在easyui开发过程中遇到下边两个事儿 combogrid/combotree做级联: $("#" + deptId).combotree( { url : u ...

  9. C#方法中的ref和out

    ref        通常我们向方法中传递的是值.方法获得的是这些值的一个拷贝,然后使用这些拷贝,当方法运行完毕后,这些拷贝将被丢弃,而原来的值不将受到影响.此外我们还有其他向方法传递参数的形式,引用 ...

  10. 【Scala】Scala技术栈

    快速了解Scala技术栈 我无可救药地成为了Scala的超级粉丝.在我使用Scala开发项目以及编写框架后,它就仿佛凝聚成为一个巨大的黑洞,吸引力使我不得不飞向它,以至于开始背离Java.固然Java ...