C# 等值锁定
using System;
using System.Collections.Generic;
using System.Linq;
using System.Text;
using System.Threading; namespace FZJ.Lock
{
/// <summary>
/// 等值锁定
/// 锁定给定内容
/// 内容必须实现IComparable接口,若Comparable比较两个对象是同一个值,
/// 则在相等对象上执行的操作是同步的
/// 实际上未对给定对象进行锁定,在外部可以调用lock等
/// </summary>
public class EquivalentLock<T> where T : IComparable<T>
{
Dictionary<T, Semaphore> t2Event = new Dictionary<T, Semaphore>(); System.Threading.SpinLock sl = new SpinLock();
/// <summary>
/// 进入锁定内容
/// </summary>
/// <param name="lockObj">被锁定的内容</param>
public void Enter(T lockObj)
{
bool lockTaken = false;
sl.Enter(ref lockTaken);
if (!t2Event.ContainsKey(lockObj))
{
t2Event.Add(lockObj, new Semaphore(, ));
}
sl.Exit();
t2Event[lockObj].WaitOne();
}
/// <summary>
/// 退出锁定内容
/// </summary>
/// <param name="lockObj">锁定的内容</param>
public void Exit(T lockObj)
{
if (!t2Event.ContainsKey(lockObj))
{
throw new KeyNotFoundException();
}
t2Event[lockObj].Release();
}
/// <summary>
/// 释放存储资源
/// </summary>
public void Free()
{
t2Event.Clear();
}
}
}
方法调用方式。
class Program
{
static void Main(string[] args)
{ EquivalentLock<string> stringLock = new EquivalentLock<string>(); for (int i = ; i < ; i++)
{
new Thread(() =>
{
string ss = new string('', ); int threadHashCode = System.Threading.Thread.CurrentThread.GetHashCode();
Console.WriteLine(threadHashCode + "尝试进来");
stringLock.Enter(ss);
//do something
Console.WriteLine(threadHashCode + "进来");
Thread.Sleep();
Console.WriteLine(threadHashCode + "出来");
stringLock.Exit(ss); }).Start();
} Console.WriteLine("是否释放资源?(y/n)");
string isFree = Console.ReadLine();
if (isFree == "y")
{
stringLock.Free();
}
Console.Read();
}
}
C# 等值锁定的更多相关文章
- 记录一下MySql update会锁定哪些范围的数据
目录 1.背景 2.前置知识 2.1 数据库的隔离级别 2.2 数据库版本 2.3 数据库的存储引擎 2.4 锁是加在记录上还是索引上 2.5 update...where加锁的基本单位是 2.6 行 ...
- ECS Linux 服务器解除ssh登陆后被锁定或暂停输入输出的终端
在使用SSH终端(如Xshell)登陆时,若不慎点击 Ctrl + S 按键,会导致终端很像被锁定,输入和输出都无响应. 这是由于操作系统的终端收到指令 Ctrl + S 后,会暂停终端输入输出的刷 ...
- NPOI导出数据,设置格式,锁定单元格
代码包括: 1:导出多个sheet 2:设置单元格格式 3:合并单元格 4:下拉框选项 5:输入数字限制 6:锁定单元格 static void Main(string[] ar ...
- 文件共享锁定数溢出-IWorkspaceEdit.StopEditing
在批量保存Feature至本地mdb的时候,当Feature的数量超过一定的值(该值不确定是不是Access文件的MaxLocksPerFile值,因为当MaxLocksPerFile为9500时,F ...
- Android中锁定文件的方法
androidSDK中并没有锁定文件相关的api. 但是android是基于linux操作系统的,linux比较底层,灵活性也更大,为了实现锁定文件的效果,大概有以下几种办法: 用chmod命令修改文 ...
- UWP Composition API - 锁定列的FlexGrid
需求是第一列锁定,那么怎么让锁定列不跟着滚动条向做移动呢? 其实很简单,让锁定列跟scrollviewer的滚动做反方向移动. 先看一下这个控件的模板,嗯,其实很简单,就是ListView的模板,不同 ...
- Vmware无法获取快照信息 锁定文件失败
今天早上起来发现虚拟机崩了: 造成原因: 如果使用VMWare虚拟机的时候突然系统崩溃蓝屏,有一定几率会导致无法启动, 会提示:锁定文件失败,打不开磁盘或快照所依赖的磁盘: 这是因为虚拟机在运行的时候 ...
- Python3.5 Day1作业:实现用户密码登录,输错三次锁定。
作业需求: 1.输入用户名密码 2.认证成功后显示欢迎信息 3.输错三次后锁定 实现思路: 1.判断用户是否在黑名单,如果在黑名单提示账号锁定. 2.判断用户是否存在,如果不存在提示账号不存在. 3. ...
- Oracle账户解锁/锁定
1. 首先用系统账号登录: sqlplus /nolog conn /as sysdba 2. 输入命令对账户解锁/锁定: ALTER USER scott ACCOUNT UNLOCK ALTER ...
随机推荐
- mongo 固定集合,大文件存储,简单优化 + 三招解决MongoDB的磁盘IO问题
1.固定集合 > db.createCollection(, max:});//固定集合 必须 显式创建. 设置capped为true, 集合总大小xxx字节, [集合中json个数max] { ...
- Scope of a Declaration
6.3. Scope of a Declaration The scope of a declaration of a member m declared in or inherited by an ...
- 推荐几个好用的maven仓库镜像站
1.阿里云的镜像站(速度很快) <mirror> <id>nexus-aliyun</id> <name>Nexus aliyun</name&g ...
- Android对敏感数据进行MD5加密(基础回顾)
1.在工具类的包下新建一个进行md5加密的工具类MD5Utils.java package com.example.mobilesafe.utils; import java.security.Mes ...
- C# OracleHelper
using System; using System.Configuration; using System.Data; using System.Collections; using Oracle. ...
- [心平气和读经典]The TCP/IP Guide(004)
The TCP/IP Guide [Page 44, 45, 46] Structure and Organization of The TCP/IP Guide | TCP/IP指南的组织结构 Yo ...
- python实例:在列表,字典,集合中,根据条件筛选数据
1. 从列表中过滤掉 负数 from random import randint # 随机生成列表 data = [randint(-10, 10) for _ in range(10)] print ...
- 我与ARM的那些事儿1初识ARM
最近一直在研究ARM,说到ARM,我们首先想到了是三星.高通等公司,这些公司都制造CPU的,其实ARM也是一家公司,只不过它是提供最核心的逻辑电路,而且它的赚钱方式是与其他公司进行双赢的!你卖出多少芯 ...
- mklink /d 目录符号链接
刚装好Windows Live Writer,却发现日志保存路径是默认的改都没法改,在C:\Users\用户名\Documents\My Weblog Posts下. 找了下,竟然可以用cmd的mkl ...
- 第9章 scrapy-redis分布式爬虫
9-1 分布式爬虫要点 1.分布式的优点 充分利用多机器的宽带加速爬取 充分利用多机的IP加速爬取速度 问:为什么scrapy不支持分布式? 答:在scrapy中scheduler是运行在队列的,而队 ...