C# 高效率编程 “多线程” 的基本使用

简介: C# 高效率编程 “多线程” 的基本使用

英文意思:

什么是多线程?

比如你需要建房子,如果使用单线程,房子的门,地板,水管等都是你一个人安装,这样效率特别的低 总知就是 “终究还是一个人扛下了所有”。

但是在开一个线程就可以把你一部分工作分给另一人(另一个线程)做,这样就不会导致你累死了(程序的假死)

例图:

image.png

CPU执行方式

单核CPU:

如果在单核CPU运行多线程程序,那么他将在线程中来回切换速度非常的快,感觉不出来

多核CPU:

多核CPU运行多线程,才是真正的多线程,同时执行

下面以例子介绍他的使用方法

实例

命名空间

using System.Threading;

创建一个窗体应用程序

写一个方法

void a() {

for (int i = 0; i <= 1000000; i++){

textBox1.Text = i.ToString();

}

}

按钮里调用

a();//调用方法

运行点击按钮,程序卡死一段时间,这是因为循环在主线程未结束造成的,

但是创建一个线程让他执行程序就不会卡死,把之前的调用删除

按钮里创建线程

Thread th = new Thread(a);

//创建一个线程,执行方法a的代码

th.Start();

//告诉CPU可以执行这个线程了

运行的时候跳异常了 ,这是因为“胯线程”了

跨线程的解决方法

之所以出异常是因为创建的“线程”去访问了“textBox1.Text”

而“textBox1.Text"文本框的控件是在主线程中创建的

解决方法:

在窗体加载的时禁止”跨线程“的检测

CheckForIllegalCrossThreadCalls = false;

//写在窗体下

这样就可以运行了

但是运行的速度非常的快,一秒钟就到大几千了,给他加一个时间间隔

线程的间隔时间

Thread.Sleep(1000);

//间隔1秒 单位:毫秒

这样一秒钟就加一个数字了

程序已经关闭了,为什么Vs中还显示在运行?

因为程序的线程在前台,程序关闭后线程还在继续执行,直到运行完,如果是个死循环那么将不会结束

解决方法:

Thread th = new Thread(a);
   //创建一个线程,执行方法a的代码 
 th.IsBackground = true;
      //在后台执行
   th.Start();
  //告诉CPU可以执行这个线程了

前台线程与后台线程

前台线程(默认):程序关闭但线程还在执行,程序还没真正的关闭,直到代码运行完才关闭,关闭了但还没完全关闭

后台线程:程序关闭后,线程也一起关闭

th.IsBackground = true;

//设置成后台线程

这个例子就结束了!!

线程间参数的传递

这是一个方法体,传递参数到a1 a2 上

static int a (int a1,int a2) {

int b = a1 + a2;

Console.Write(b);

}

传递方式1(建议使用):

Thread th = new Thread(()=>a(1,1));

//创建一个线程,传递两个 1 的参数

th.Start();

//开始线程

===============================

传递方式2(单参数)

方法类型必须是 object 类型的 否则无法传递,而且只能单个参数,必须得类型转换

创建方法:

static void a (object a1) {

int b = Convert.ToInt32(a1);

Console.Write(b);

}

传递参数:

Thread th = new Thread(a);

//创建一个线程

th.Start(“1”);

//开始线程

线程命名

这个好像没什么用…

Thread.CurrentThread.Name = “马冬梅”;

//给当前线程命名(主线程)

Console.WriteLine(Thread.CurrentThread.Name);

//输出主线程的名字

Thread th = new Thread(a);

//创建一个线程

th.Name = “小马哥的棺材”;

//给创建的线程命名

static void  a () 
      {
  Console.WriteLine(Thread.CurrentThread.Name);
          输出当前线程名        "小马哥的棺材"
    }

运行结果:

等待线程执行完后在执行

编写程序中需要等一个线程执行完后在继续执行下面的语句,例如加载一些东西等

th.Join(); //等待这个线程执行完

Thread th = new Thread(a);

//创建一个线程

th.Start(); //开始线程

th.Join(); //等待这个线程执行完

Console.Write(“小马哥的棺材板”);

static   void  a() {
        Console.WriteLine("线程在执行");
        Thread.Sleep(3000);
        //线程间隔3秒                        
    }

使用这个方法需要等待这个线程执行完成后才会继续执行后面的代码

纯手打,点个赞呗~

相关文章
|
6天前
|
安全 Java 调度
Java编程时多线程操作单核服务器可以不加锁吗?
Java编程时多线程操作单核服务器可以不加锁吗?
21 2
|
11天前
|
API C#
C# 一分钟浅谈:文件系统编程
在软件开发中,文件系统操作至关重要。本文将带你快速掌握C#中文件系统编程的基础知识,涵盖基本概念、常见问题及解决方法。文章详细介绍了`System.IO`命名空间下的关键类库,并通过示例代码展示了路径处理、异常处理、并发访问等技巧,还提供了异步API和流压缩等高级技巧,帮助你写出更健壮的代码。
26 2
|
11天前
|
Java 调度 开发者
Java中的多线程编程:从基础到实践
本文旨在深入探讨Java多线程编程的核心概念和实际应用,通过浅显易懂的语言解释多线程的基本原理,并结合实例展示如何在Java中创建、控制和管理线程。我们将从简单的线程创建开始,逐步深入到线程同步、通信以及死锁问题的解决方案,最终通过具体的代码示例来加深理解。无论您是Java初学者还是希望提升多线程编程技能的开发者,本文都将为您提供有价值的见解和实用的技巧。
15 2
|
13天前
|
Java 数据处理
Java中的多线程编程:从基础到实践
本文旨在深入探讨Java中的多线程编程,涵盖其基本概念、创建方法、同步机制及实际应用。通过对多线程基础知识的介绍和具体示例的演示,希望帮助读者更好地理解和应用Java多线程编程,提高程序的效率和性能。
19 1
|
15天前
|
SQL 开发框架 安全
并发集合与任务并行库:C#中的高效编程实践
在现代软件开发中,多核处理器普及使多线程编程成为提升性能的关键。然而,传统同步模型在高并发下易引发死锁等问题。为此,.NET Framework引入了任务并行库(TPL)和并发集合,简化并发编程并增强代码可维护性。并发集合允许多线程安全访问,如`ConcurrentQueue&lt;T&gt;`和`ConcurrentDictionary&lt;TKey, TValue&gt;`,有效避免数据不一致。TPL则通过`Task`类实现异步操作,提高开发效率。正确使用这些工具可显著提升程序性能,但也需注意任务取消和异常处理等常见问题。
27 1
|
6天前
|
Java
COMATE插件实现使用线程池高级并发模型简化多线程编程
本文介绍了COMATE插件的使用,该插件通过线程池实现高级并发模型,简化了多线程编程的过程,并提供了生成结果和代码参考。
|
8天前
|
Java 数据处理 调度
Java中的多线程编程:从基础到实践
本文深入探讨了Java中多线程编程的基本概念、实现方式及其在实际项目中的应用。首先,我们将了解什么是线程以及为何需要多线程编程。接着,文章将详细介绍如何在Java中创建和管理线程,包括继承Thread类、实现Runnable接口以及使用Executor框架等方法。此外,我们还将讨论线程同步和通信的问题,如互斥锁、信号量、条件变量等。最后,通过具体的示例展示了如何在实际项目中有效地利用多线程提高程序的性能和响应能力。
|
9天前
|
安全 算法 Java
Java中的多线程编程:从基础到高级应用
本文深入探讨了Java中的多线程编程,从最基础的概念入手,逐步引导读者了解并掌握多线程开发的核心技术。无论是初学者还是有一定经验的开发者,都能从中获益。通过实例和代码示例,本文详细讲解了线程的创建与管理、同步与锁机制、线程间通信以及高级并发工具等主题。此外,还讨论了多线程编程中常见的问题及其解决方案,帮助读者编写出高效、安全的多线程应用程序。
|
10天前
|
安全 Java 调度
python3多线程实战(python3经典编程案例)
该文章提供了Python3中多线程的应用实例,展示了如何利用Python的threading模块来创建和管理线程,以实现并发执行任务。
12 0
|
11天前
|
存储 缓存 Java
JAVA并发编程系列(11)线程池底层原理架构剖析
本文详细解析了Java线程池的核心参数及其意义,包括核心线程数量(corePoolSize)、最大线程数量(maximumPoolSize)、线程空闲时间(keepAliveTime)、任务存储队列(workQueue)、线程工厂(threadFactory)及拒绝策略(handler)。此外,还介绍了四种常见的线程池:可缓存线程池(newCachedThreadPool)、定时调度线程池(newScheduledThreadPool)、单线程池(newSingleThreadExecutor)及固定长度线程池(newFixedThreadPool)。
下一篇
无影云桌面