并发编程/线程同步/线程同步深入/线程池/异步编程/Tas任务

2023-10-24 21:50

本文主要是介绍并发编程/线程同步/线程同步深入/线程池/异步编程/Tas任务,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

一:并发编程:

《1》:进程
通俗的讲,一个exe运行一次就会产生一个进程,一个exe的多个进程之间数据互相隔离。
1.一个进程里至少有一个线程:主线程。我们平时写的控制台程序默认就是单线程的,代码从上往下执行,一行执行完了再执行下一行;
2.什么是多线程:一个人一边烧水一边洗衣服比“先烧水再洗衣服”效率高。同一时刻一个人做多件件事情,只是在“快速频繁切换”,如果处理不当可能比不用多线程效率还低。讨论多线程先只考虑“单核cpu”。
3.普通的代码是从上向下执行的,但是多线程的代码可以“并行”执行,我们可以把“线程”理解成独立的执行单元,线程中的代码可以“并行执行”。线程根据情况被分配给一定的“时间片”来运行,可能一个线程还没执行完,就又要把时间片交给别的线程执行。把要在单独的线程放到一个方法中,然后创建 Thread 对象,运行它,这个 Thread 中的代码就会在单独的线程中执行。
4. 多线程的好处:有很大可能增加系统的运行效率;开发winform程序,避免界面卡;注册后向用户发送欢迎邮件,如果发送邮件很慢的话,避免注册过程很慢。
5. 线程默认是“非后台线程”,一个程序必须所有“非后台线程”执行结束后程序才会退出, 否则看起来好像是主线程退出了,其实进程还没有结束(搞一个winform 程序演示)把线程设置为“后台线程”后,所有“非后台线程”执行结束后程序就会退出,不会等“后台线程”执行结束:
thread.IsBackground = true;
简单的验证:控制台程序,如果不加 t1.IsBackground = true; 是线程执行结束才退出。加上的话就是“闪退”。

二:线程同步

《1》:定义:
线程同步问题就是解决多个线程同时操作一个资源的问题,多个线程对于资源的使用,必须等所有的线程使用完成之后再进行处理
while(th1.IsAlive);操作会大量消耗cpu空转,可以改成th1.Join()就是让当前线程等待th1线程的结束。

class Program{static int count = 0;   //定义一个变量static void Main(string[] args){//实例化一个线程对象用th1表示Thread th1 = new Thread(() =>{for (int i = 0; i < 10; i++){count++;Console.WriteLine("th1:" + count);Thread.Sleep(100);   //将当前线程挂起100ms}});th1.Start();   //线程的调用Thread th2 = new Thread(() =>{for (int i = 0; i < 10; i++){count++;Console.WriteLine("th2:" + count);Thread.Sleep(100);}});th2.Start();while (th1.IsAlive)    //获取当前线程执行状态的值并处于死循环{}while (th2.IsAlive){}Console.WriteLine(count);     //最终输出结果countConsole.ReadLine();}}

在这里插入图片描述

《2》:实现:
(1):Join
原理,等待耗时最长的线程执行完成之后在处理公共资源,给耗时最长的线程调用Join方法
(2):lock
改用lock解决多个线程同时操作一个资源。lock是C#中的关键字,他要锁定一个资源
lock的特点是:同时只能有一个线程进入lock的对象的范围,其他lock的线程就要等。

class Program{static int count = 0;    //定义一个静态的变量static Object o = new Object();    //新实例化一个静态的object对象static void Main(string[] args){Console.WriteLine(DateTime.Now.ToLongTimeString());//实例化一个线程对象用th1表示Thread th1 = new Thread(() =>{for (int i = 0; i < 10; i++){lock (o)    //同时只能有一个线程进入lock的对象的范围,其他lock的线程就要等。{count++;}Console.WriteLine("th1:" + count);Thread.Sleep(100);   //线程休眠时间100ms}});th1.Start();   //启动线程Thread th2 = new Thread(() => //Lambda表达式传值   实际上是构建了一个匿名函数 通过函数闭包来传值{for (int i = 0; i < 10; i++){lock (o){count++;}Console.WriteLine("th2:" + count);

这篇关于并发编程/线程同步/线程同步深入/线程池/异步编程/Tas任务的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/277995

相关文章

如何使用celery进行异步处理和定时任务(django)

《如何使用celery进行异步处理和定时任务(django)》文章介绍了Celery的基本概念、安装方法、如何使用Celery进行异步任务处理以及如何设置定时任务,通过Celery,可以在Web应用中... 目录一、celery的作用二、安装celery三、使用celery 异步执行任务四、使用celery

Springboot的ThreadPoolTaskScheduler线程池轻松搞定15分钟不操作自动取消订单

《Springboot的ThreadPoolTaskScheduler线程池轻松搞定15分钟不操作自动取消订单》:本文主要介绍Springboot的ThreadPoolTaskScheduler线... 目录ThreadPoolTaskScheduler线程池实现15分钟不操作自动取消订单概要1,创建订单后

详谈redis跟数据库的数据同步问题

《详谈redis跟数据库的数据同步问题》文章讨论了在Redis和数据库数据一致性问题上的解决方案,主要比较了先更新Redis缓存再更新数据库和先更新数据库再更新Redis缓存两种方案,文章指出,删除R... 目录一、Redis 数据库数据一致性的解决方案1.1、更新Redis缓存、删除Redis缓存的区别二

深入理解C++ 空类大小

《深入理解C++空类大小》本文主要介绍了C++空类大小,规定空类大小为1字节,主要是为了保证对象的唯一性和可区分性,满足数组元素地址连续的要求,下面就来了解一下... 目录1. 保证对象的唯一性和可区分性2. 满足数组元素地址连续的要求3. 与C++的对象模型和内存管理机制相适配查看类对象内存在C++中,规

什么是cron? Linux系统下Cron定时任务使用指南

《什么是cron?Linux系统下Cron定时任务使用指南》在日常的Linux系统管理和维护中,定时执行任务是非常常见的需求,你可能需要每天执行备份任务、清理系统日志或运行特定的脚本,而不想每天... 在管理 linux 服务器的过程中,总有一些任务需要我们定期或重复执行。就比如备份任务,通常会选在服务器资

C语言线程池的常见实现方式详解

《C语言线程池的常见实现方式详解》本文介绍了如何使用C语言实现一个基本的线程池,线程池的实现包括工作线程、任务队列、任务调度、线程池的初始化、任务添加、销毁等步骤,感兴趣的朋友跟随小编一起看看吧... 目录1. 线程池的基本结构2. 线程池的实现步骤3. 线程池的核心数据结构4. 线程池的详细实现4.1 初

Python使用asyncio实现异步操作的示例

《Python使用asyncio实现异步操作的示例》本文主要介绍了Python使用asyncio实现异步操作的示例,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋... 目录1. 基础概念2. 实现异步 I/O 的步骤2.1 定义异步函数2.2 使用 await 等待异

Java子线程无法获取Attributes的解决方法(最新推荐)

《Java子线程无法获取Attributes的解决方法(最新推荐)》在Java多线程编程中,子线程无法直接获取主线程设置的Attributes是一个常见问题,本文探讨了这一问题的原因,并提供了两种解决... 目录一、问题原因二、解决方案1. 直接传递数据2. 使用ThreadLocal(适用于线程独立数据)

C#反射编程之GetConstructor()方法解读

《C#反射编程之GetConstructor()方法解读》C#中Type类的GetConstructor()方法用于获取指定类型的构造函数,该方法有多个重载版本,可以根据不同的参数获取不同特性的构造函... 目录C# GetConstructor()方法有4个重载以GetConstructor(Type[]

Python中的异步:async 和 await以及操作中的事件循环、回调和异常

《Python中的异步:async和await以及操作中的事件循环、回调和异常》在现代编程中,异步操作在处理I/O密集型任务时,可以显著提高程序的性能和响应速度,Python提供了asyn... 目录引言什么是异步操作?python 中的异步编程基础async 和 await 关键字asyncio 模块理论