这是我的方法的两个变体,它返回一个与枚举值关联的字符串(保存在字典中)。第一个变体较慢,但线程安全,第二个变体更快,但我不知道它是否是线程安全的。第一的:
string GetStringForEnum (SomeEnum e)
{
string str = null;
lock (someDictionary) //someDictionary is not used anywhere else (only in this method)
{ if (!someDictionary (e, out str)) { someDictionary.Add (e, "somehowCreatedString"); }
return str;
}
第二种变体:
string GetStringForEnum (SomeEnum e)
{
string str = null;
if (!someDictionary (e, out str))
{
lock (someDictionary) //someDictionary is not used anywhere else (only in this method)
{ if (!someDictionary (e, out str)) { someDictionary.Add (e, "somehowCreatedString"); }
}
return str;
}
第二种变体不是每次都使用“锁”,但它是否是线程安全的?
这里有两个问题:
lock (someDictionary)
- 不建议这样做,即使字典不在其他地方使用。这是一个理论论证,但 Dictionary 类的(未来)代码可以锁定自身。
if (!someDictionary (e, out str))
没有锁。我认为这是一个电话TryGetValue()
。这根本不是线程安全的,您的读取可能会被另一个线程中的写入中断。这可能会导致各种错误(索引超出范围、空引用)。这些错误非常罕见(=难以重现)。
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系:hwhale#tublm.com(使用前将#替换为@)