草庐IT

edi-dictionary-viewer

全部标签

c# - Dictionary 是否损坏或 GetHashCode() 应该仅基于不可变成员?

将对象添加到.NET时System.Collections.Generic.Dictionaryclass内部存储了key的hashcode,用于后面的比较。当hashcode在初始插入字典后发生变化时,它通常会变得“不可访问”,并且当存在检查(即使使用相同的引用)返回false时可能会让用户感到惊讶(下面的示例代码)。GetHashCode文档说:TheGetHashCodemethodforanobjectmustconsistentlyreturnthesamehashcodeaslongasthereisnomodificationtotheobjectstatethatdet

c# - IDictionary<string, string> 与 Dictionary<string, string>

在这里使用IDictionary的值(value)是什么? 最佳答案 使用接口(interface)的值(value)始终相同:切换到另一个后端实现时,您不必更改客户端代码。请考虑稍后分析您的代码表明哈希表实现(在Dictionary类中使用)不适合您的任务,二叉搜索树的性能会更好。如果您已经编码到一个接口(interface),那么切换实现就很简单了。但是,如果您使用的是具体类,则必须在更多地方更改更多代码。=>这会花费时间和金钱。 关于c#-IDictionary与Dictionar

c# - 比 Dictionary<Type, X> 更快的选择?

我正在创建一个正在进行性能测试的库。在其中我生成了一个Dictionary一次。这些项目当前以随机顺序插入。字典在应用程序生命周期内保持不变。然后它经常用于查找项目。查找是库中较大的瓶颈之一。是的,我正在微观优化,但要学习。我想知道是否有更好的方法来获得查找性能?更新我使用dotTrace来衡量性能。报告+dotTrace在我的家用电脑中,所以我这里没有报告(本可以上传到其他地方)。我使用了这里的测试:https://github.com/danielpalme/IocPerformance字典定义可在此处找到:https://github.com/jgauffin/Griffin.C

c# - : Dictionary<string, object> 或 Dictionary<enum,object> 哪个更快/更有效?

enum类型用作字典键时是否比string类型更快/更有效?IDictionaryorIDictionary事实上,哪种数据类型最适合作为字典键,为什么?请考虑以下事项:注意:为简单起见,只有5个属性structMyKeys{publicstringIncomplete="IN";publicstringSubmitted="SU";publicstringProcessing="PR";publicstringCompleted="CO";publicstringClosed="CL";}和enumMyKeys{Incomplete,Submitted,Processing,Comp

c# - Json Serialize Dictionary<Enum, Int32> 的问题

每当我尝试序列化字典时,我都会得到异常:System.ArgumentException:Type'System.Collections.Generic.Dictionary`2[[Foo.DictionarySerializationTest+TestEnum,Foo,Version=1.0.0.0,Culture=neutral,PublicKeyToken=null],[System.Int32,mscorlib,Version=2.0.0.0,Culture=neutral,PublicKeyToken=b77a5c561934e089]]'isnotsupportedfors

c# - 用 foreach 遍历 Dictionary,这是按什么顺序完成的?

假设我有一个字典,我按特定顺序添加每个键和值条目。现在,如果我希望稍后能够以添加条目的相同顺序迭代此Dictionary,这是我在该字典上使用简单的foreach循环获得的顺序吗?如果没有,我会很高兴听到我该怎么做,我知道这可以用List而不是Dictionary轻松完成,但我不想到。谢谢 最佳答案 普通的Dictionary不保证项目的顺序。你需要OrderedDictionary如果您想维护添加到其中的订单项目。请注意,在.Net框架中没有此类的通用版本,因此要么必须放弃一些类型安全性,要么找到其他实现(即https://www

c# - 将 Dictionary<string, string> 转换为 Dictionary<string, object> 的最简单方法是什么?

我使用的API返回键值集合作为Dictionary.我需要将其转换为Dictionary.我觉得应该有一种方法可以在不“手动”遍历每个键值对的情况下进行这种转换/映射,但谷歌搜索或C#对象引用并没有立即产生解决方案。 最佳答案 尝试以下操作varnewMap=oldMap.ToDictionary(pair=>pair.Key,pair=>(object)pair.Value); 关于c#-将Dictionary转换为Dictionary的最简单方法是什么?,我们在StackOverfl

c# - 如何证明 Dictionary 的 TryGetValue 的双重检查锁定模式不是线程安全的

最近我看到一些C#项目在Dictionary上使用双重检查锁定模式。像这样:privatestaticreadonlyobject_lock=newobject();privatestaticvolatileIDictionary_cache=newDictionary();publicstaticobjectCreate(stringkey){objectval;if(!_cache.TryGetValue(key,outval)){lock(_lock){if(!_cache.TryGetValue(key,outval)){val=newobject();//factorycon

c# - 散列过程如何在 Dictionary<TKey, TValue> 中工作

Dictionary中的散列过程是如何工作的?我读到使用字典可以更快地查找。但是没看懂怎么办?散列和映射到索引是如何发生的?找不到任何好的引用。编辑:如何从哈希函数的结果中得到对象实际存储的内存位置? 最佳答案 哈希表或字典是一种存储键值对的数据结构。哈希表的优点是给定一个键找到对应的值是相当快的。简而言之,在哈希表中查找键值对的时间不依赖于表的大小。将其与将键值对存储在列表或数组中进行比较。要查找键值对,您必须从头开始搜索列表,直到找到匹配的键。列表越长,查找键值对所需的时间就越多。使用大O表示法,您可以说在哈希表中查找键的顺序为

c# - 为什么 Crystal Report Viewer 在 WePOS 操作系统上总是要求提供 Access 数据库的登录详细信息?

我使用链接到此处C:\MyData.mdb的Access数据库的CrystalReportsXI编写了一份报告。该报告只有一个字段(针对此示例进行了简化)并且没有子报告。我在C#.NET4中使用了Forms和WPFCyrtsalReportViewer。报告在我运行WindowsXP的开发PC和其他同样运行WindowsXP的“收银台”上成功查看。但是,在运行WePOS(一种简化版WindowsXP)的收银机上,报告“总是”显示一个对话框,询问登录详细信息,即用户名和密码。此对话框还显示C:\MyData.mdb的正确路径。我为此花了很多天,以各种可能的方式进行测试(我相信每个人都记得