草庐IT

Generics

全部标签

c# - 为什么 c# 编译器在使用具有 new() 约束的泛型类型调用 new 时发出 Activator.CreateInstance?

当你有如下代码时:staticTGenericConstruct()whereT:new(){returnnewT();}C#编译器坚持发出对Activator.CreateInstance的调用,这比native构造函数慢得多。我有以下解决方法:publicstaticclassParameterlessConstructorwhereT:new(){publicstaticTCreate(){return_func();}privatestaticFuncCreateFunc(){returnExpression.Lambda>(Expression.New(typeof(T)))

c# - 通用协变和逆变

这个问题在这里已经有了答案:QuestionaboutC#covariance(4个答案)关闭9年前。考虑代码片段。IListobj=newList();IEnumerableobj1=obj;但是如果我写ICollectionobj2=obj;它抛出一个编译时错误。Cannotimplicitlyconverttype'System.Collections.Generic.IList'to'System.Collections.Generic.ICollection'.为什么自List以来出现此行为同时实现IEnumerable和ICollection还有IList定义为public

c# - 类型参数 'T' 与外部类型 '...' 的类型参数同名

publicabstractclassEntityBase{...}publicinterfaceIFoobar{voidFoo(intx)whereT:EntityBase,new();}publicinterfaceIFoobarwhereT:EntityBase,new(){voidFoo(intx);}publicclassFoobar:IFoobar,IFoobarwhereT:EntityBase,new(){publicvoidFoo(intx){...}voidIFoobar.Foo(intx){Foo(x);}}我收到编译器警告:Typeparameter'T'has

具有不同参数的两个方法的 C# 委托(delegate)

我正在使用以下方法:publicvoidM1(Int32a){//acquireMyMutexDoSomething(a);//releaseMyMutex}和publicvoidM2(Strings,Stringt){//acquireMyMutexDoSomethingElse(s,t);//releaseMyMutex}根据我目前的发现,似乎不可能对具有不同签名的两个方法使用一个委托(delegate)。有没有其他的替代方法来写这样的东西:publicvoidUsingMutex(...){//acquireMyMutex...//releaseMyMutex}UsingMute

c# - 如何将类型传递给方法 - 类型参数与泛型

我有一个类似于工厂的对象的方法。你给它一个类型,它创建一个实例并做一些其他的事情。一种优雅的方式(在我看来)是这样的:publicTMagicMethod()whereT:SomeBaseClass{//Magicgoeshere}但这让FxCop感到不安,他说这是一种糟糕的风格-我收到“CA1004:通用方法应提供类型参数”警告。关于不使用推理之类的东西。所以,我能想到的唯一其他方法是这样的:publicSomeBaseClassMagicMethod(TypeT){//Samemagicgoeshere}我相信这在很多帐户上都不如第一种方法,但样式规则......关于警告的MSDN

c# - Func<> 的 List<>,具有通用返回类型的编译错误,但为什么呢?

这个问题有点长,所以请耐心等待。我需要在一组字符串和每个字符串对应的通用方法调用之间创建一个映射。但是,我遇到了一个编译问题,下面进行了解释。在我的场景中,我使用的是Dictionary,但问题同样存在于List.为简单起见,我使用List在下面的示例中。考虑这三个类:publicabstractclassMyBase{/*bodyomitted*/}publicclassMyDerived1:MyBase{/*bodyomitted*/}publicclassMyDerived2:MyBase{/*bodyomitted*/}还有一些其他类中的方法:publicclassTest{p

c# - List<T> - 我传递的是对象还是引用?

好吧,我研究了泛型并有以下问题:Listlist=newListSomeClassMyInstance=SomeClass();list.Add(MyInstance);我不确定将添加到列表中的是什么-引用或引用类型的对象(指向MyInstance的实际值)。编辑:或者我将添加指向实际对象的值(即引用数据类型)?谢谢 最佳答案 当你处理引用类型时,你总是在处理引用,因此引用将被添加到列表中(实际上是引用的副本)。您实际上没有选择;这就是语言的工作原理。 关于c#-List-我传递的是对象

c# - List<T>.Remove 应该放在 List<T>.Exists 之前吗?

拥有Listpaths=newList();我想删除我不确定是否存在的项目。我应该检查它是否存在,还是直接运行Remove方法?是if(paths.Exists(stringVar))在paths.Remove(stringVar)之前需要或考虑好的做法?如果列表中没有这样的项目,则在没有Exists的情况下运行Remove将简单地返回false。 最佳答案 不,它不会抛出异常,也不需要额外的检查。见MSDN:trueifitemissuccessfullyremoved;otherwise,false.Thismethodalso

C# 转换继承的通用接口(interface)

我在转换我想出的界面时遇到了一些麻烦。它是C#Windows窗体的MVP设计。我有一个IView类,我在我的表单类上实现了它。还有一个IPresenter,我派生到各种特定的Presenter中。每个Presenter将根据角色以不同方式管理IView,例如打开对话框以使用AddPresenter输入一组新数据,而不是使用EditPresenter编辑现有数据,后者会将数据预加载到表单中。其中每一个都继承自IPresenter。我想这样使用代码:AddPresenterpres=newAddPresenter();我基本上可以正常工作,但是这些演示者和它们管理的View被捆绑到插件中,

c# - 泛型警告 T 与其他类型的类型同名

鉴于以下publicclassService:IService{Repository_repository=newRepository();publicTGet(intid){return_repository.Get(id);}}publicinterfaceIService{TGet(intid);}我收到以下警告Typeparameter'T'hasthesamenameasthetypeparameterfromoutertype'Services.IService'我不确定这有什么问题,为什么它关心我的返回类型是否与我告诉类的类型相同。我在这里遗漏了什么吗?