草庐IT

list_of_strings

全部标签

c# - 返回 ICollection<T> 而不是 List<T> 的真正优势是什么?

这个问题在这里已经有了答案:关闭13年前。我读过几篇博文,其中提到对于公共(public)API,我们应该始终返回ICollection(或IEnumerable)而不是List。返回ICollection而不是List的真正优势是什么?谢谢!重复:WhatisthedifferencebetweenList(ofT)andCollection(ofT)?

c# - "Object reference not set to an instance of an object": why can't . NET 显示更多细节?

“对象引用未设置到对象的实例”为什么异常不显示对象引用字段的名称,或者至少不显示它的类型?这可能是.NET中最常见的运行时错误之一。尽管System.Exception有堆栈跟踪,但没有其他有用的详细信息。在一年的时间里,我花了几个小时筛选堆栈跟踪(通常是在我没有编写的代码中),希望有一个来自“.pdb”文件的行号,然后在代码中找到该行,甚至那么该行中的哪个引用为空通常并不明显。拥有引用字段的名称会非常方便。如果System.ArgumentNullException实例可以显示方法参数的名称(“值不能为空。参数名称:值”),那么System.NullReferenceExceptio

c# - 生产中的 Azure SDK 2.2 : Could not load file or assembly 'msshrtmi' or one of its dependencies. 系统找不到指定的文件

我已经在StackOverflow和其他网站的其他几个线程上读到过这个问题。其他解决方案都没有解决我的问题,而且大多数都已过时,引用了旧版本的AzureSDK。我有一个典型的Azure网站角色部署到Azure,它使用Microsoft.WindowsAzure.Diagnostics.DiagnosticMonitorTraceListener来记录跟踪消息。发生跟踪时,看起来好像DiagnosticMonitorTraceListener正在使用RoleEnvironment类,该类又会尝试加载显然不存在的msshrtmi.dll.这是记录到Azure文件系统的堆栈跟踪的一部分:[F

c# - 性能问题 : comparing to String. 格式

不久前,JonSkeet的一篇文章在我脑海中植入了构建一个CompiledFormatter类的想法,用于在循环中使用而不是String.Format()。这个想法是对String.Format()的调用部分花在解析格式字符串上的开销;我们应该能够通过将该代码移出循环来提高性能。当然,诀窍是新代码应该完全匹配String.Format()行为。这周我终于做到了。我经历了使用.NetframeworksourceprovidedbyMicrosoft直接调整他们的解析器(事实证明String.Format()实际上将工作交给了StringBuilder.AppendFormat())。我

c# - 为什么我应该返回 IList<T> 而不是 List<T>?

这个问题在这里已经有了答案:关闭11年前。PossibleDuplicate:C#-ListorIList写满了所以你应该返回IList从你的方法而不是List但我找不到任何真正好的理由。我一直在寻找执行此操作的代码,然后调用代码通常会执行以下两项操作之一:调用newList(returnedIList)所以它可以使用List上的所有好方法转换回List所以它可以使用List上的所有好方法第一个很笨重,第二个会抛出(运行时)InvalidCastException如果实现实际上更改为其他东西(这使得它完全愚蠢)。如果我使用List出于某种原因必须用IList的实现替换它我不能从List

c# - 为什么 List<T>.Enumerator 比我的实现更快?

由于各种巨大的性能优势(在我的例子中),我发现自己处于必须滚动我自己的动态数组实现的位置。但是,在为我的版本创建一个枚举器并将效率与List使用的枚举器进行比较后,我有点困惑;Listone比我的版本快大约30-40%,尽管它要复杂得多。这是List枚举器实现的重要部分:publicstructEnumerator:IEnumerator,IDisposable,IEnumerator{privateListlist;privateintindex;privateintversion;privateTcurrent;internalEnumerator(Listlist){this.l

c# - WPF ComboBox : static list of ComboBoxItems, 但数据绑定(bind) SelectedItem?

在我的WPF应用程序中,我有一个ComboBox,其中填充了ComboBoxItems的静态列表,因为它的内容永远不会改变。但是,因为我想将SelectedItem数据绑定(bind)到我的底层ViewModel,所以我希望每个ComboBoxItem也有一个单独的值,该值将分配给我的ViewModel属性。我在让它工作时遇到了一些麻烦。我的ComboBox声明如下:此ComboBox的SelectedItem绑定(bind)到ViewModel的Amount属性,该属性声明为整数:publicclassMyViewModel:INotifyPropertyChanged{privat

c# - 为什么 string.IsNullOrEmpty 比比较快?

这个问题在这里已经有了答案:WhyisString.IsNullOrEmptyfasterthanString.Length?(7个答案)关闭9年前。出于性能原因,MSAnalyzer建议使用string.IsNullOrEmpty而不是将其与null或空字符串进行比较警告470CA1820:Microsoft.Performance:将...中的“string.operator==(string,string)”调用替换为对“String.IsNullOrEmpty”的调用。这是为什么呢?调用另一个函数并将其传递给某个对象的引用(无论如何都需要执行某种比较)的要求难道不应该比执行比较

c# - "if (object is (string, Color))"c# 7.0 元组用法不起作用

我使用的是VisualStudio2017RC,我已经安装了System.ValueTuple包,它启用了新的c#7.0元组用法,但我无法让它在这种特定情况下工作:如您所见,第一种方法没有任何红色波浪线,而且很管用。但是尝试执行ois(string,Color)失败并出现不相关的错误:新的元组不能这样用吗?或者它只是包裹的当前状态?我已经将它更新到最新版本btw,此时是4.3.0。我读过thisMSDNpost但没有发现任何这样的用法。 最佳答案 Roslyncontainsteststhatensureusingtuplesinp

c# - string str 和 string str=null 的区别

我想知道当我们声明一个变量时内部到底发生了什么,就像这样:stringtr;stringtr=null;在调试时,我注意到这两个值都只显示空值。但是当使用reftr而不初始化null时,它会给出错误,而第二行不会。请帮助我深入了解它 最佳答案 你的第一条语句只是声明,你的第二条语句是声明+初始化。stringtr;//JustDeclarationstringtr=null;//Declaration+Initialization.如果您尝试仅在声明中使用tr,您可能会遇到编译时错误。(第一种情况)例如:stringtr;//Jus