using System;
using System.Diagnostics;
using System.Threading;
using System.Threading.Tasks;
using static System.Console; //任务同步
//1.lock 锁定一个引用类型的变量
/*死锁
lock (_s1)
{
lock (_s2)
{}
} lock (_s2)
{
lock (_s1)
{}
}
*/
//2.Interlocked类,更快但只支持少数几种的操作
//public int State
//{
// get
// {
// lock (this)
// {
// return ++_state;
// }
// }
//}
//相当于
//public int State
//{
// get
// {
// return Interlocked.Increment(ref _state);
// }
//} //3.Monitor类
//4.SpinLock结构,传递时需加引用,不然结构会以值传递
// 如果有大量锁定,如列表的每一个节点都有一个锁定,且锁定时间非常短,SpinLock结构就很有用
// 它与Monitor类似,Enter TryEnter Exit //5.WaitHandle 抽象基类 用于等待一个信号(WaitOne() WaitAll() ...)
//6.Mutex类 操作系统能识别有名称的互斥,可以跨线程,如果没有指定名称则不在不同的进程之间共享
//7.Semaphore类 非常类似于互斥,区别是它可以同时由多个线程使用,是一种计数的互斥
//8.Event类 事件与互斥和信号量一样,也是一个系统范围内的资源同步方法
// ManualResetEvent AutoResetEvent ManualResetEventSlim CountdownEvent
//9.Barrier类 ReaderWriterLockSlim类 //10.Timer类
// Threading中的Timer 基于XAML应用程序的DispatcherTimer namespace ConsoleApp
{
public class StateObject
{
private int _state = ;
private object _sync = new object(); public void ChangeState(int loop)
{ lock (_sync)//方法2.
{
if (_state == )
{
_state++;
Trace.Assert(_state == ,
$"Race condition occured after {loop} loops");
}
_state = ;
}
} }
class Program
{
static void Main(string[] args)
{
//RaceCondition(); object o = new object();
lock (o) { }
//lock由编译器解析为Monitor类
Monitor.Enter(o);
try { }
finally { Monitor.Exit(o); } //Monitor可以设置等待时间
bool _lockTaken = false;
Monitor.TryEnter(o, , ref _lockTaken);
if (_lockTaken)//get the lock
{
try { }
finally { Monitor.Exit(o); }
}
else { } //互斥
bool createNew;
//第3个为输出参数,接收一个表示互斥是否为新建的布尔值,
//如果(createNew)返回为false就表示互斥已经定义
var mutex = new Mutex(false, "ProCSharpMutex", out createNew); if (mutex.WaitOne())
{
try { }
finally { mutex.ReleaseMutex(); }
}
else
{
//some problem happened while waiting
} //信号量
int taskCount = ;
int semaphoreCount = ;
var semaphore = new Semaphore(semaphoreCount-, semaphoreCount);//初始请求数 最大请求数
try
{
int preCount = semaphore.Release();
WriteLine($"preCount: {preCount}");
}
catch (Exception) { } var tasks = new Task[taskCount];
for (int i = ; i < taskCount; ++i)
{
tasks[i] = Task.Run(() => TaskMain(semaphore));
}
Task.WaitAll(tasks);
WriteLine("All tasks finished"); //事件
AutoResetEvent autoEvent = new AutoResetEvent(false);
autoEvent.Reset();
autoEvent.Set(); autoEvent.WaitOne(); //Timer
using (var timer1 = new Timer(TimeAction, null, /*TimeSpan.FromSeconds(0)*/, /*TimeSpan.FromSeconds(3)*/))
{
Task.Delay().Wait();
} ReadKey();
} public static void RaceCondition()
{
var state = new StateObject();
//开启2个Task
for (int i = ; i < ; ++i)
{
Task.Run(() =>
{
int j = ;
while (true)
{
lock (state)//方法1.
{
state.ChangeState(j++);
}
}
});
}
} public static void TaskMain(Semaphore semaphore)
{
bool isComplete = false;
while(!isComplete)
{
if (semaphore.WaitOne())//等到 计数-1
{
try
{
WriteLine($"Task {Task.CurrentId} locks the semaphore");
Task.Delay().Wait();
}
finally
{
WriteLine($"Task {Task.CurrentId} release the semaphore");
semaphore.Release(); //释放 计数+1
isComplete = true;
}
}
else
{
WriteLine($"Timeoue for task {Task.CurrentId}; wait again");
}
}
} private static void TimeAction(object o)
{
WriteLine($"System.Threading.Timer {DateTime.Now:T}");
} }
}

C#任务同步的更多相关文章

  1. [ 高并发]Java高并发编程系列第二篇--线程同步

    高并发,听起来高大上的一个词汇,在身处于互联网潮的社会大趋势下,高并发赋予了更多的传奇色彩.首先,我们可以看到很多招聘中,会提到有高并发项目者优先.高并发,意味着,你的前雇主,有很大的业务层面的需求, ...

  2. FFmpeg学习6:视音频同步

    在上一篇文章中,视频和音频是各自独立播放的,并不同步.本文主要描述了如何以音频的播放时长为基准,将视频同步到音频上以实现视音频的同步播放的.主要有以下几个方面的内容 视音频同步的简单介绍 DTS 和 ...

  3. SQLServer事务同步下如何收缩日志

    事务同步是SQLServer做读写分离的一种常用的方式. 随着业务数据的不断增长,数据库积攒了大量的日志,为了腾出硬盘空间,需要对数据库日志进行清理 订阅数据库的日志清理 因为订阅数据库所有的数据都来 ...

  4. 多线程的通信和同步(Java并发编程的艺术--笔记)

    1. 线程间的通信机制 线程之间通信机制有两种: 共享内存.消息传递.   2. Java并发 Java的并发采用的是共享内存模型,Java线程之间的通信总是隐式执行,通信的过程对于程序员来说是完全透 ...

  5. .NET Core采用的全新配置系统[10]: 配置的同步机制是如何实现的?

    配置的同步涉及到两个方面:第一,对原始的配置文件实施监控并在其发生变化之后从新加载配置:第二,配置重新加载之后及时通知应用程序进而使后者能够使用最新的配置.要了解配置同步机制的实现原理,先得从认识一个 ...

  6. C#多线程之线程同步篇3

    在上一篇C#多线程之线程同步篇2中,我们主要学习了AutoResetEvent构造.ManualResetEventSlim构造和CountdownEvent构造,在这一篇中,我们将学习Barrier ...

  7. C#多线程之线程同步篇2

    在上一篇C#多线程之线程同步篇1中,我们主要学习了执行基本的原子操作.使用Mutex构造以及SemaphoreSlim构造,在这一篇中我们主要学习如何使用AutoResetEvent构造.Manual ...

  8. C#多线程之线程同步篇1

    在多线程(线程同步)中,我们将学习多线程中操作共享资源的技术,学习到的知识点如下所示: 执行基本的原子操作 使用Mutex构造 使用SemaphoreSlim构造 使用AutoResetEvent构造 ...

  9. [.NET] 怎样使用 async & await 一步步将同步代码转换为异步编程

    怎样使用 async & await 一步步将同步代码转换为异步编程 [博主]反骨仔 [出处]http://www.cnblogs.com/liqingwen/p/6079707.html  ...

  10. Javascript 代理模式模拟一个文件同步功能

    <!DOCTYPE html> <html lang="en"> <head> <meta charset="UTF-8&quo ...

随机推荐

  1. Vue项目中的RSA加解密

    前后端使用rsa加密:  一般是客户端初始化时访问登录服务时,服务端面动态生成一对RSA对,公钥传给客户端,客户端拿到后,用户输入密码后,点登录时用公钥加密返回给服务端,服务端用私钥解就行了 一.安装 ...

  2. 需求规格说明书(SRS)特点

    需求说明书的7大特征: 完整性 正确性 可行性 必要性 划分优先级 无二义性 可验证性 每条需求规格说明书的4大特点: 完整性 一致性 可修改性 可跟踪性 需求管理就是一种获取.组织并记录系统需求的系 ...

  3. Mac下使用国内镜像安装Homebrew

    First MBP上的brew很老了,就想把brew更新一下,顺便安装一下NodeJs.无奈更新的过程一直卡在网络下载,毫不动弹.想想,应该是Repo访问不到的原因,于是重装brew. 根据官网上的方 ...

  4. 22 python 初学(类,面向对象)

    python: 函数式 + 面向对象 函数式可以做所有的事,是否合适? 面向对象: 一.定义: 函数: def + 函数名(参数) 面向对象: class  -> 名字叫 Bar 类 def   ...

  5. 18 python 初学(time、random 模块)

    # _author: lily # _date: 2019/1/13 import time import datetime print(help(time)) # print(time.time() ...

  6. 监控zookeeper

    [4ajr@db1 scripts]$ cat zookeeper_mode.sh #!/bin/bash mode=`echo srvr|nc 127.0.0.1 2181|awk '/Mode/{ ...

  7. mysql中group by和order by混用 结果不是理想结果(转)

    文章转自 https://www.cnblogs.com/myphper/p/3767572.html 在使用mysql排序的时候会想到按照降序分组来获得一组数据,而使用order by往往得到的不是 ...

  8. ZJOI2019做题笔记

    麻将(期望.DP套DP) 先考虑如何计算一个子集是否能胡. 设\(f_{i,0/1,j,k}\)表示考虑了子集中\(1 \sim i\)的牌,是否找到对子,\(i-1,i,i+1\)预计拿\(j\)个 ...

  9. 《Effective C++》实现:条款26-条款31

    条款26:尽可能延后变量定义式的出现时间 C++推荐在使用对象前才定义对象(调用构造函数赋初值) 只在循环中使用的变量定义在循环内部(除非"赋值"成本低于"构造+析构&q ...

  10. Linux 学习 (五) 压缩与解压缩命令

    Linux达人养成计划 I 学习笔记 常用压缩格式:.zip | .gz | .bz2 | .tar.gz | .tar.bz2 .zip zip 压缩文件名 源文件:压缩文件 zip -r 压缩文件 ...