时间:2021-05-19
复制代码 代码如下:
/// <summary>共享锁</summary>
public class ShareLock
{
ReaderWriterLock Lock;
IDisposable readLock, writeLock;
public IDisposable ReadLock { get { Lock.AcquireReaderLock(-1); return readLock; } }
public IDisposable WriteLock { get { Lock.AcquireWriterLock(-1); return writeLock; } }
public IDisposable UpgradeLock { get { return new UpgraderLocked(Lock); } }
/// <summary>释放所有锁</summary>
public void ReleaseLock() { Lock.ReleaseLock(); }
public ShareLock()
{
this.Lock = new ReaderWriterLock();
this.readLock = new Locked(Lock.ReleaseReaderLock);
this.writeLock = new Locked(Lock.ReleaseWriterLock);
}
class Locked : IDisposable
{
ThreadStart ReleaseLock;
public Locked(ThreadStart ReleaseLock) { this.ReleaseLock = ReleaseLock; }
public void Dispose() { this.ReleaseLock(); }
}
class UpgraderLocked : IDisposable
{
delegate void ReleaseLockHandler(ref LockCookie lockCookie);
ReleaseLockHandler ReleaseLock;
LockCookie Cookie;
public UpgraderLocked(ReaderWriterLock locker)
{
Cookie = locker.UpgradeToWriterLock(-1);
this.ReleaseLock = locker.DowngradeFromWriterLock;
}
public void Dispose() { this.ReleaseLock(ref Cookie); }
}
}
声明:本页内容来源网络,仅供用户参考;我单位不保证亦不表示资料全面及准确无误,也不保证亦不表示这些资料为最新信息,如因任何原因,本网内容或者用户因倚赖本网内容造成任何损失或损害,我单位将不会负任何法律责任。如涉及版权问题,请提交至online#300.cn邮箱联系删除。
1.SharedandExclusiveLockssharedlock(译:共享锁)exclusivelock(译:排它锁、独占锁)InnoDB实现了标准的行级
一、前言MySQL的锁按照范围可以分为全局锁、表锁、行锁,其中行锁是由数据库引擎实现的,并不是所有的引擎都提供行锁,MyISAM就不支持行锁,所以文章介绍行锁会
sqlserver锁定模式有三种:共享(S锁),更新(U锁),排他(X锁);S锁是共享锁,如果事务T对数据A加上共享锁后,则其他事务只能对A再加共享锁,不能加排
MySQL的锁按照范围可以分为全局锁、表锁、行锁,其中行锁是由数据库引擎实现的,并不是所有的引擎都提供行锁,MyISAM就不支持行锁,所以文章介绍行锁会以Inn
本文实例讲述了Java实现指定线程执行顺序的三种方式。分享给大家供大家参考,具体如下:方法一:通过共享对象锁加上可见变量来实现。publicclassMySer