上一页 1 ··· 8 9 10 11 12 13 14 15 16 ··· 25 下一页
摘要: 线程池 线程池全称为托管线程池,线程池受 .NET 通用语言运行时(CLR)管理,线程的生命周期由 CLR 处理,因此我们可以专注于实现任务,而不需要理会线程管理。 线程池的应用场景:任务并行库 (TPL)操作、异步 I/O 完成、计时器回调、注册的等待操作、使用委托的异步方法调用和套接字连接。 很 阅读全文
posted @ 2020-04-27 16:19 痴者工良 阅读(15822) 评论(4) 推荐(16) 编辑
摘要: 前面我们学习了很多用于线程管理的 类型,也学习了多种线程同步的使用方法,这一篇主要讲述线程等待相关的内容。 在笔者认真探究多线程前,只会new Thread;锁?Lock;线程等待?Thread.Sleep()。 前面已经探究了创建线程的创建姿势和各种锁的使用,也学习了很多类型,也使用到了很多种等待 阅读全文
posted @ 2020-04-26 22:58 痴者工良 阅读(9595) 评论(0) 推荐(6) 编辑
摘要: 本篇的内容主要是介绍 ReaderWriterLockSlim 类,来实现多线程下的读写分离。 ReaderWriterLockSlim ReaderWriterLock 类:定义支持单个写线程和多个读线程的锁。 ReaderWriterLockSlim 类:表示用于管理资源访问的锁定状态,可实现多 阅读全文
posted @ 2020-04-25 16:56 痴者工良 阅读(5776) 评论(6) 推荐(3) 编辑
摘要: 前言 这一篇,我们将学习用于实现并行任务、使得多个线程有序同步完成多个阶段的任务。 应用场景主要是控制 N 个线程(可随时增加或减少执行的线程),使得多线程在能够在 M 个阶段中保持同步。 线程工作情况如下: 我们接下来 将学习C# 中的 Barrier ,用于实现并行协同工作。 Barrier 类 阅读全文
posted @ 2020-04-25 09:22 痴者工良 阅读(2025) 评论(4) 推荐(1) 编辑
摘要: 解决一个问题 假如,程序需要向一个 Web 发送 5 次请求,受网路波动影响,有一定几率请求失败。如果失败了,就需要重试。 示例代码如下: class Program { private static int count = 0; static void Main(string[] args) { 阅读全文
posted @ 2020-04-19 21:50 痴者工良 阅读(1698) 评论(5) 推荐(3) 编辑
摘要: 区别与示例 AutoResetEvent 和 ManualResetEvent 十分相似。两者之间的区别,在于前者是自动(Auto),后者是手动(Manua)。 你可以先运行下面的示例,再测试两者的区别。 AutoResetEvent 示例: class Program { // 线程通知 priv 阅读全文
posted @ 2020-04-19 15:40 痴者工良 阅读(1426) 评论(0) 推荐(2) 编辑
摘要: 回顾一下,前面 lock、Monitor 部分我们学习了线程锁,Mutex 部分学习了进程同步,Semaphor 部分学习了资源池限制。 这一篇将学习 C# 中用于发送线程通知的 AutoRestEvent 类。 AutoRestEvent 类 用于从一个线程向另一个线程发送通知。 微软文档是这样介 阅读全文
posted @ 2020-04-19 08:58 痴者工良 阅读(3617) 评论(0) 推荐(5) 编辑
摘要: Semaphore、SemaphoreSlim 类 两者都可以限制同时访问某一资源或资源池的线程数。 这里先不扯理论,我们从案例入手,通过示例代码,慢慢深入了解。 Semaphore 类 这里,先列出 Semaphore 类常用的 API。 其构造函数如下: 构造函数 说明 Semaphore(In 阅读全文
posted @ 2020-04-18 21:57 痴者工良 阅读(2145) 评论(0) 推荐(3) 编辑
摘要: Mutex 类 Mutex 中文为互斥,Mutex 类叫做互斥锁。它还可用于进程间同步的同步基元。 Mutex 跟 lock 相似,但是 Mutex 支持多个进程。Mutex 大约比 lock 慢 20 倍。 互斥锁(Mutex),用于多线程中防止两条线程同时对一个公共资源进行读写的机制。 Wind 阅读全文
posted @ 2020-04-18 16:58 痴者工良 阅读(8321) 评论(6) 推荐(9) 编辑
摘要: 本章主要讲述多线程竞争下的原子操作。 知识点 竞争条件 当两个或两个以上的线程访问共享数据,并且尝试同时改变它时,就发生争用的情况。它们所依赖的那部分共享数据,叫做竞争条件。 数据争用是竞争条件中的一种,出现竞争条件可能会导致内存(数据)损坏或者出现不确定性的行为。 线程同步 如果有 N 个线程都会 阅读全文
posted @ 2020-04-18 10:04 痴者工良 阅读(11106) 评论(0) 推荐(10) 编辑
上一页 1 ··· 8 9 10 11 12 13 14 15 16 ··· 25 下一页