har*_*316 4 .net c# garbage-collection mutex keep-alive
所以这告诉我,我应该在我的代码末尾放置一个GC.KeepAlive以保持我的互斥锁打开(以防止我的应用程序的多个实例由于早期GC处理我的互斥锁而发生).但是我应该将KeepAlive放在我的finally块中还是在try块的末尾?
我个人不会使用这种方法.
问题是您需要在应用程序代码(在本例中为表单)完成后使用互斥锁,或者它将成为GC后优化的候选者.
由于Mutex实现了IDisposable,您可以轻松地执行此操作:
[STAThread]
static void Main() // args are OK here, of course
{
bool ok;
using(var mutex = new System.Threading.Mutex(true, "YourNameHere", out ok))
{
if (!ok)
{
MessageBox.Show("Another instance is already running.");
return;
}
Application.Run(new Form1());
}
}
Run Code Online (Sandbox Code Playgroud)
这也可以正常工作,因为最终由using语句创建将阻止互斥锁成为GC候选者.我个人认为,这个代码不那么混乱和清晰.
话虽这么说,如果您想要从该链接中遵循该方法,只需将KeepAlive置于任何位置将导致不会收集互斥锁,并防止出现此问题.您可以将它放在try或finally块中 - 只要它在主应用程序代码"完成"之后.您也可以忽略这一点并且只是明确地Dispose()使用互斥锁 - 只要您以某种方式使用互斥锁,就可以了.
| 归档时间: |
|
| 查看次数: |
278 次 |
| 最近记录: |