草庐IT

buts_list

全部标签

c# 对 List<KeyValuePair<int, string>> 进行排序

在C#中,我想对List>进行排序按列表中每个字符串的长度。在Psuedo-Java中,这将是匿名的,看起来像这样:Collections.Sort(someList,newComparator>({publicintcompare(KeyValuePairs1,KeyValuePairs2){return(s1.Value.Length>s2.Value.Length)?1:0;//specifymysortingcriteriahere}});如何获得上述功能? 最佳答案 C#中的等效项是使用lambda表达式和Sort方法:s

c# - 为什么将 List<T> 转换为 IList<T> 会导致性能下降?

我在做一些性能指标时遇到了一些对我来说很奇怪的事情。我为以下两个函数计时:privatestaticvoidDoOne(){ListA=newList();for(inti=0;iA=newList();for(inti=0;iL=A;ints=0;for(intj=0;j即使在Release模式下编译,计时结果始终显示DoTwo比DoOne花费大约100倍的时间:DoOnetook0.06171706seconds.DoTwotook8.841709seconds.鉴于List直接实现IList这一事实,我对结果感到非常惊讶。谁能澄清这种行为?血淋淋的细节回答问题,这里是完整的代码和

c# - 如何将 List<String> 转换为 Dictionary<int,String>

我有List,我需要将其转换为Dictionary自动生成key,有什么最短的方法可以实现吗?我试过:vardictionary=newDictionary();intindex=0;list.ForEach(x=>{definitions.Add(index,x);index++;});但我认为这是肮脏的方式。 最佳答案 vardict=list.Select((s,i)=>new{s,i}).ToDictionary(x=>x.i,x=>x.s); 关于c#-如何将List转换为Di

c# - 如何从逗号分隔的字符串创建 List<T>?

给定变量stringids=Request.QueryString["ids"];//"1,2,3,4,5";有没有办法把它转换成一个列表而不用做类似的事情ListmyList=newList();foreach(stringidinids.Split(',')){if(int.TryParse(id)){myList.Add(Convert.ToInt32(id));}} 最佳答案 要从头开始创建列表,请使用LINQ:ids.Split(',').Select(i=>int.Parse(i)).ToList();如果您已经有了列表

c# - 用一定数量的元素初始化 List<>

这个问题在这里已经有了答案:HowtoinitializeaListtoagivensize(asopposedtocapacity)?(16个答案)InitializeaListwithLINQquery(6个答案)关闭8年前。假设我有一个简单的List.我想初始化它并向其中添加例如100个元素。为此,我可以:varmyList=newList();for(inti=0;i但这不是最优雅的方法。有没有内置的方法来简化它?我不想要任何循环,只是出于好奇

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

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

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# - “不要公开通用列表”,为什么在方法参数中使用 collection<T> 而不是 list<T>

我正在使用FxCop,它显示“不要公开通用列表”的警告,建议使用Collection而不是List.首选它的原因,我知道所有这些东西,如thisSOpost中所述和MSDN以及我浏览过的更多文章。但我的问题是,我很少有方法可以进行如此繁重的计算,并且方法接受List的参数。就性能而言,这应该更快更好。但是FxCop也为此发出警告。所以一个选择是我应该将参数声明为Collection,然后使用ToList()在方法内部,然后使用它。那么优化了哪一个呢?“抑制这种情况下的警告”或“在参数中使用Collection,然后在方法本身内部使用ToList()”。 最佳