- c - 在位数组中找到第一个零
- linux - Unix 显示有关匹配两种模式之一的文件的信息
- 正则表达式替换多个文件
- linux - 隐藏来自 xtrace 的命令
我只是使用简单的锁来管理一些共享数据。
有没有办法知道哪个线程拿了锁?
基本上有人已经获得了锁并且没有释放它。所以,后面的所有操作都是简单的敲打锁和超时。
我有点卡住了,因为从调试器开始,它只是卡在锁定状态,因为有人已经获得了它,我在“Break All”之后查看了“Debugger + Windows+ Threads”——没有线程进入锁定状态。
它没有显示任何进入临界区的线程。
有可能有人获得了锁并且该线程已被中止。但我希望即使线程已中止也能释放锁。我的期望错了吗?
这是我的类(class) - 基本上它是一个 powershell cmd runner 并且 cmd 可以从多个线程执行:
internal abstract class PowerShellCommandRunner : IDisposable
{
#region Fields
protected object m_syncObject = new object();
private PSSession m_psSession = null;
private Runspace m_runspace = null;
#endregion
#region Constructor
public PowerShellCommandRunner(ExchangeApplicationSystem system)
{
if (null == system)
{
throw new ArgumentNullException("ExchangeApplicationSystem");
}
this.ExchangeApplicationSystem = system;
this.PSCredential = this.ExchangeApplicationSystem.Credential.GetPSCredential();
}
#endregion
#region Properties
internal ExchangeApplicationSystem ExchangeApplicationSystem
{
get;
private set;
}
public PSCredential PSCredential
{
get;
protected set;
}
private bool IsNotInitializedOrInvalidRunspace(Runspace runspace)
{
bool flag = (null == runspace) //not initialized
|| (null == runspace.RunspaceStateInfo) //not state info (defensive)
|| (runspace.RunspaceStateInfo.State == RunspaceState.Broken) //runspace state is broken
|| (null != runspace.RunspaceStateInfo.Reason); //there is an exception
return flag;
}
private bool NeedToCreatePsSession
{
get
{
bool flag = (null == this.m_psSession)
|| this.IsNotInitializedOrInvalidRunspace(this.m_psSession.Runspace);
return flag;
}
}
internal Runspace Runspace
{
get
{
lock (this.m_syncObject)
{
if (this.IsNotInitializedOrInvalidRunspace(this.m_runspace))
{
if (null != this.m_runspace)
{
//already have one runspace - close it, before we create another one
this.CloseRunspace();
}
this.m_runspace = RunspaceFactory.CreateRunspace();
this.m_runspace.Open();
}
return this.m_runspace;
}
}
}
#endregion
#region Methods
internal IEnumerable<PSObject> Execute(string cmd, params object[] argumentList)
{
if (string.IsNullOrEmpty(cmd))
{
throw new ArgumentNullException("cmd");
}
return this.Execute(new Command(cmd), argumentList);
}
/// <summary>
/// Sub-classes can do their own specific implementation to create ps-sessions
/// The base class simply performs primitive oepratiosn like managing them.
/// </summary>
/// <returns></returns>
internal abstract PSSession GetPSSession();
/// <summary>
/// Gets the pssession and if reuired updates it as well
/// </summary>
/// <returns></returns>
private PSSession GetAndUpdateManagePSSessionInfRequired()
{
//Note: we dont need to lock as the callers (Exceute methods) will be acquiring the lock before executing the code
//but, just locking it again as the locks are re-entrant
lock (this.m_syncObject)
{
if (this.NeedToCreatePsSession)
{
if (null != this.m_psSession
&& (null != this.m_runspace))
{
//if ps-session exists, remove it from runspace
this.RemovePsSessionFromRunspace();
//Yes, there can be a case where some one already have a reference to the remove session
//that's ok, as the operation simply throws
//And subsequently they will be releasing and re-using the new one.
this.m_psSession = null;
}
//now, open a new session (requesting for a new session from subclasses)
this.m_psSession = this.GetPSSession();
Debug.Assert(null != this.m_psSession);
}
return this.m_psSession;
}
}
internal IEnumerable<PSObject> Execute(Command cmd, params object[] argumentList)
{
if (null == cmd)
{
throw new ArgumentNullException("cmd");
}
lock (this.m_syncObject)
{
//Pipelines cannot be executed concurrently, so serialize it
OperationProgressReporter.Report(string.Format("Executing the following PowerShell Command: {0}", cmd.ToString()));
return this.Runspace.ExecuteCommand(cmd, this.GetAndUpdateManagePSSessionInfRequired(), argumentList);
}
}
internal IEnumerable<PSObject> Execute(ScriptBlock sb, params object[] argumentList)
{
if (null == sb)
{
throw new ArgumentNullException("scriptblock");
}
lock (this.m_syncObject)
{
//Pipelines cannot be executed concurrently, so serialize it
OperationProgressReporter.Report(string.Format("Executing the following PowerShell Command: {0}", sb.ToString()));
return this.Runspace.ExecuteCommand(sb, this.GetAndUpdateManagePSSessionInfRequired(), argumentList);
}
}
private void RemovePsSessionFromRunspace()
{
//not intended to call before acquiring a lock
//(For ex: either while closing runspace or while getting rid of old session and getting a new one (GetAndUpdateManagePSSessionInfRequired)
//but locking it as the locks are re-entrant (defensive)
lock (this.m_syncObject)
{
if ((null != this.m_psSession)
&& (null != this.m_runspace))
{
try
{
string errorMsg = null;
this.m_runspace.RemovePsSessionFromRunspace(this.m_psSession, out errorMsg);
if (!string.IsNullOrEmpty(errorMsg))
{
FxTracing.TraceError(TraceEventId.GeneralError, errorMsg);
}
}
catch (Exception ex)
{
ExceptionManager.GeneralExceptionFilter(ex);
OperationProgressReporter.Report(OperationProgressMessageLevel.Verbose,
string.Format("<DEBUG> Unable to remove PSsession from runspace in '{0}'", this.ExchangeApplicationSystem));
}
}
}
}
private void CloseRunspace()
{
//lcok it
lock (this.m_syncObject)
{
//check again to make sure only one thread enters
if (null != this.m_runspace)
{
try
{
//if a ps-session is created, remove it
if (null != this.m_psSession)
{
//remove the pssession from runspace
this.RemovePsSessionFromRunspace();
}
//then close the runspace
this.m_runspace.Close();
}
catch (Exception ex)
{
//swallow
ExceptionManager.GeneralExceptionFilter(ex);
Debug.Fail(ex.Message);
}
finally
{
//finally, set the runspace to null
//Yes, the runspace can be set to null while another thread can have a reference to old runspace
//its ok as the operation simply fail with invalid runspace state exception (most likely)
//And when they retry they get the updated runspace or get a new one.
//same appraoch as managing ps-session
this.m_runspace = null;
}
}
}
}
#endregion
#region IDisposable
public void Dispose()
{
this.CloseRunspace();
}
#endregion
}
最佳答案
也许这会有所帮助:
.load sos
然后键入 !SyncBlk -a
关于c# - 如何知道哪个线程最好使用 Visual Studio 调试器(.net 编程)锁定?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/16880730/
我经常使用 SSMS 查询数据和构建数据集,我的 IT 部门负责数据库管理。 最近我发现了 Azure Data Studio,我喜欢: 智能感知 源代码控制(例如使用 Git) 来自社区的扩展 SQ
我想根据我使用的 visual studio 版本编译不同的东西,比如 #if VISUAL_STUDIO_VERSION > 2015 eventH?.Invoke(this, EventArgs.
我们的开发团队计划从 visual studio 2005 升级到 visual studio 2010 -- 跳过 visual studio 2008。 大部分项目是VB ASP.NET项目,使用
我的Visual Studio 2015无法构建2010平台工具集。它说: The build tools for Visual Studio 2010 (v100) cannot be found.
我目前正在使用 Visual Studio 2015 来编程 ASP.NET Core 应用程序。我对安装 Visual Studio 2017 有以下疑问: 什么被认为是最佳实践和/或最干净的方法?
尝试从扩展和更新获取 Visual Studio 扩展时,出现以下错误:- 向 visualstudiogallery.msdn.microsoft.com/Services/VStudio/Exte
这个问题在这里已经有了答案: Can Visual Studio Code and VS 2012 be installed on same computer? (1 个回答) 关闭去年。 在安装了
作为标准安装的一部分,Visual Studio Code 带有一个名为“Monokai Dimmed”的颜色主题。 有没有办法将它移植到 Visual Studio 2015?我检查了社区主题( h
我想开始编程 CUDA。 我已经安装了 Visual Studio 2010 Express。 我还安装了 nVidia nSight Visual Studio。 而且我具备所有常见的先决条件(Ne
Visual Studio Community Edition是否可以使用Visual Studio Online帐户上的存储库? 我一直为包含在Online帐户中的Visual Studio Onl
我有一个我一直在开发的应用程序,但在 android studio 上遇到了问题。当我点击“build->run”然后选择我的设备时,应用程序永远不会在我的手机上运行(并且自动出现的android-s
我正在使用Visual Studio2010。我面临的一个问题是,当我创建一个新的Web项目时,Visual Studio将创建该项目,并且不会在解决方案资源管理器中显示其解决方案。 另一件事是,我想
我通读了这里的许多帖子,却找不到一个有效的明确答案。因此,在花了一些时间使它生效之后,我认为应该发布它。 问题:发布配置文件将建立在服务器上,但不会发布。 解: 确保已安装Microsoft Wind
我正在尝试使用Visual Studio 2012构建针对.NET 3.5的C++ CLI应用程序。 通过安装Visual Studio 2008,并指定v90平台工具集,我已经在一台机器上进行了这项
我在 Microsoft Visual Studios 2013 中有一个项目,我想在 Microsoft Visual Studios 2010 中打开它。有什么简单的方法吗?还是我必须在2010年
我想知道,如果我发送一个解决方案文件夹(它是用 visual studio C# 编写的),您可以在 visual studio for mac 中打开解决方案吗? 在visual studio 20
有没有办法在 Visual Studio Code 和 Visual Studio 中设置相同的快捷方式(而不必每次都手动更改它们)? 例如,我在 Visual Studio Code 中经常使用 A
我刚开始了解 Visual Studio Code。我想知道,我可以将 Visual Studio 替换为所有 .NET 开发相关的工作吗? 我可以节省 Visual Studio 许可的成本吗? V
我安装了具有有效许可证(Visual Studio 订阅)的 Visual Studio 2019 企业版(VS 2019 16.1.4),它运行良好。 突然之间,当我尝试打开项目或项目中的任何文件时
我一直在使用 Compass 编译 Windows 环境中的 sass 文件,无论是在命令行上还是使用 Compass-app 来查看目录。 我刚刚开始使用 Visual Studio(专业版 201
我是一名优秀的程序员,十分优秀!