当使用a Guid作为a 的索引时Dictionary,使用该Guid对象或Guid的字符串表示更好吗?
我刚刚重构了一些使用字符串来使用该对象的代码,因为new Guid()遍布整个地方都有调用.但这让我想知道性能问题可能是什么.(这些集合相当小,但它们会被多次迭代.)
哪个会更快?
bool same=(Guid)Identifier==id;
bool same=String.Equals(string1,string2, StringComparison.OrdinalIgnoreCase);
Run Code Online (Sandbox Code Playgroud) 在下面的C#代码中,cboRole返回一个Guid.
然后我尝试在switch语句中使用它来做一些动作.
cboRole只能返回4个不同的Guid所以我觉得开关对我来说是个不错的选择.
问题是所有情况都被忽略了,我总是得到默认动作.当我调试时,我清楚地看到cboRole返回一个类似于以下printscreen的值.
在C#switch语句中"比较"Guid的正确方法是什么
码:
if (!cboRole.IsNull)
{
switch (cboRole.EditValue.ToStringEx())
{
case "532E8EED-9E72-42E0-871E-36470C1AE327":
param1 = "4E08BA7C-E81F-40AE-92F0-DF33A98DD0BB";
MessageBox.Show("It's working");
break;
case "FA7637E9-A9E4-4D57-A59B-80615424D27F":
param1 = "E540C382-F22C-4FE2-9068-1E10AA8DD076";
break;
case "2734CCD9-93E6-4A86-8B83-5EA9E62FA921":
param1 = "8A54F8D5-5B74-4B3F-A29A-D423AA8DD02E";
break;
default:
MessageBox.Show("Not Working");
break;
}
Run Code Online (Sandbox Code Playgroud)

这可以作为数据存储(SQL Server)的ID使用吗?
我会使用guid,但我更喜欢数值.