Blue Dream

记录成长的每一个脚印,写下漫长的程序人生
随笔 - 4, 文章 - 121, 评论 - 1, 阅读 - 89514
  首页  :: 订阅 订阅  :: 管理
< 2025年3月 >
23 24 25 26 27 28 1
2 3 4 5 6 7 8
9 10 11 12 13 14 15
16 17 18 19 20 21 22
23 24 25 26 27 28 29
30 31 1 2 3 4 5

Visual C#中编写多线程程序之起步

Posted on   Dennis  阅读(146)  评论(0编辑  收藏  举报
.NET将关于多线程的功能定义在System.Threading名字空间中。因此,要使用多线程,必须先声明引用此名字空间(using System.Threading;)。

  即使你没有编写多线程应用程序的经验,也可能听说过“启动线程”“杀死线程”这些词,其实除了这两个外,涉及多线程方面的还有诸如“暂停线程”“优先级”“挂起线程”“恢复线程”等等。下面将一个一个的解释。

  a.启动线程

  顾名思义,“启动线程”就是新建并启动一个线程的意思,如下代码可实现:

Thread thread1 = new Thread(new ThreadStart( Count));

  其中的 Count 是将要被新线程执行的函数。

  b.杀死线程

  “杀死线程”就是将一线程斩草除根,为了不白费力气,在杀死一个线程前最好先判断它是否还活着(通过 IsAlive 属性),然后就可以调用 Abort 方法来杀死此线程。

  c.暂停线程

  它的意思就是让一个正在运行的线程休眠一段时间。如 thread.Sleep(1000); 就是让线程休眠1秒钟。

  d.优先级

  这个用不着解释了。Thread类中有一个ThreadPriority属性,它用来设置优先级,但不能保证操作系统会接受该优先级。一个线程的优先级可 分为5种:Normal, AboveNormal, BelowNormal, Highest, Lowest。具体实现例子如下:

thread.Priority = ThreadPriority.Highest;

  e.挂起线程

  Thread类的Suspend方法用来挂起线程,知道调用Resume,此线程才可以继续执行。如果线程已经挂起,那就不会起作用。

if (thread.ThreadState = ThreadState.Running)
{
 thread.Suspend();
}

  f.恢复线程

  用来恢复已经挂起的线程,以让它继续执行,如果线程没挂起,也不会起作用。

if (thread.ThreadState = ThreadState.Suspended)
{
 thread.Resume();
}

  下面将列出一个例子,以说明简单的线程处理功能。此例子来自于帮助文档。

using System;
using System.Threading;
// Simple threading scenario: Start a static method running
// on a second thread.
public class ThreadExample {
 // The ThreadProc method is called when the thread starts.
 // It loops ten times, writing to the console and yielding
 // the rest of its time slice each time, and then ends.
 public static void ThreadProc() {
  for (int i = 0; i < 10; i++) {
   Console.WriteLine("ThreadProc: {0}", i);
   // Yield the rest of the time slice.
   Thread.Sleep(0);
  }
 }

 public static void Main() {
  Console.WriteLine("Main thread: Start a second thread.");
  // The constructor for the Thread class requires a ThreadStart
  // delegate that represents the method to be executed on the
  // thread. C# simplifies the creation of this delegate.
  Thread t = new Thread(new ThreadStart(ThreadProc));
  // Start ThreadProc. On a uniprocessor, the thread does not get
  // any processor time until the main thread yields. Uncomment
  // the Thread.Sleep that follows t.Start() to see the difference.
  t.Start();
  //Thread.Sleep(0);

  for (int i = 0; i < 4; i++) {
   Console.WriteLine("Main thread: Do some work.");
   Thread.Sleep(0);
  }

  Console.WriteLine("Main thread: Call Join(), to wait until ThreadProc ends.");
  t.Join();
  Console.WriteLine("Main thread: ThreadProc.Join has returned. Press Enter to end program.");
  Console.ReadLine();
 }
}

  此代码产生的输出类似如下内容:

Main thread: Start a second thread.
Main thread: Do some work.
ThreadProc: 0
Main thread: Do some work.
ThreadProc: 1
Main thread: Do some work.
ThreadProc: 2
Main thread: Do some work.
ThreadProc: 3
Main thread: Call Join(), to wait until ThreadProc ends.
ThreadProc: 4
ThreadProc: 5
ThreadProc: 6
ThreadProc: 7
ThreadProc: 8
ThreadProc: 9
Main thread: ThreadProc.Join has returned. Press Enter to end program.

 

(评论功能已被禁用)
编辑推荐:
· AI与.NET技术实操系列:基于图像分类模型对图像进行分类
· go语言实现终端里的倒计时
· 如何编写易于单元测试的代码
· 10年+ .NET Coder 心语,封装的思维:从隐藏、稳定开始理解其本质意义
· .NET Core 中如何实现缓存的预热?
阅读排行:
· 分享一个免费、快速、无限量使用的满血 DeepSeek R1 模型,支持深度思考和联网搜索!
· 基于 Docker 搭建 FRP 内网穿透开源项目(很简单哒)
· 25岁的心里话
· ollama系列01:轻松3步本地部署deepseek,普通电脑可用
· 按钮权限的设计及实现
点击右上角即可分享
微信分享提示