线程默认为前台线程,这意味着任何前台线程在运行都会保持程序存活。

     后台线程:只要有一个前台线程在运行,应用程序的进程就在运行。如果多个前台线程在运行,而Main()方法结束了,应用程序的进程就是激活的,直到所有前台线程完成其任务为止。

     前台线程和后台线程的唯一的区别是— 后台线程不会阻止进程终止。

     在默认情况下,用Thread 类创建的线程都是前台线程。线程池中的线程总是后台线程。

     在用Thread类创建线程时,可以设置属性IsBackground,以确定该线程是(false)前台线程还是(true)后台线程。

using System.Threading;

namespace ConsoleApplication1

{

class Program

   {
   static void myThread()
   {

   Console.WriteLine("新的线程开始输出消息");

       Console.ReadKey();
       Thread.Sleep(4000);//停止4秒中让主线程可以比NewThread提前结束

       Console.WriteLine("新的线程结束输出消息");
       Console.ReadKey();

}

static void Main(string[] args)

{

       Thread thread = new Thread(myThread);
       thread.Name = "NewThread";

   //IsBackground属性设置为false时 线程 NewThread是可以在主线程执行完毕后打印出两条消息的

       //IsBackground如果为true,则在主线程结束后,就打印不出第二条消息了 因为主线程(前台线程)结束了,后台线程也就跟着退出了。
       thread.IsBackground = false;
       thread.Start();

   Console.WriteLine("主线程已经结束");

   }
}
}

前台线程和后台线程适合的场合

      通常,后台线程非常适合于完成后台任务,应该将被动侦听活动的线程设置为后台线程,而将负责发送数据的线程设置为前台线程,这样,在所有的数据发送完毕之前该线程不会被终止。

      例如:如果关闭Word应用程序,拼写检查器继续运行器进程就没有意义了。在应用程序结束时,拼写检查器就可以关闭了。

线程的优先级

      在windows上执行的线程在执行了一定时间(一个时间片)后,windows将会进行“调度”,给线程指定优先级,可以影响这个调度。

      windows按照优先级的高低选择程序开始运行,也就是说如果存在一个优先级是25的线程能够执行,那么windows将不会调用优先级为24的线程。但是windows是一种“抢占式”的操作系

统(在windows上执行的线程能够在任何时候被抢占),如果一个具有较高优先级的线程准备好运行,并且当前运行的是较低优先级的线程,windows将迫使较低优先级线程停止运行,开始

运行较高优先级的线程。

      由于windows上线程调用是(笼统的讲)通过线程的优先级来实现的,那么如果我们想使我们的程序能够被尽量多的调度,就需要设置线程的优先级, 显卡

      在Thread类中,可以设置Priority属性,以影响线程的基本优先级。Priority属性需要一个ThreadPriority枚举定义的值。    

      Highest > AboveNormal >  Normal >  BelowNormal > Lowest

      通常情况下,我们是不需要设置线程的优先级,或者将其设置成Normal优先级。

using System.Threading;

namespace ConsoleApplication1

   {
       class Program
       {
           static bool loopSwitch = true;
           static void myThread()
           {
               long threadCount = 0;
               //进行加法操作
               while (loopSwitch) { threadCount++; }
               //显示结果
               Console.WriteLine("{0},优先级:{1}" + "数到:{2}",
               Thread.CurrentThread.Name,
               Thread.CurrentThread.Priority.ToString(),
               threadCount.ToString());
               Console.ReadLine();
           }

       static void Main(string[] args)

           {
               Thread threadOne = new Thread(myThread);
               threadOne.Name = "ThreadOne";

           Thread threadTwo = new Thread(myThread);

               threadTwo.Name = "ThreadTwo";
               threadTwo.Priority = ThreadPriority.Lowest;

           threadOne.Start();

               threadTwo.Start();
               Thread.Sleep(2000);
               loopSwitch = false;
           }
       }
   }

运行结果:

   threadTwo,优先级:Lowest数到:744795888

       threadOne,优先级:Normal数到: 745653704
       很显然线程优先级高的threadOne数的数要多一些,也就是说它执行的快一些。
       这里还要注意一个问题,线程的优先级还跟平台有关。不同的操作会对线程的调度不同,也就是说你在Windows下设的优先级到其他操作系统下可能一点用都没有。
       建议不要随便提高线程的优先级,如果线程优先级过高可能会影响其他线程的执行,从而导致严重的、难以预料的、不堪设想的后果。