草庐IT

Covariance

全部标签

c# - Task<TResult> 可以/应该包装在 C# 5.0 等待中,它在 TResult 中是协变的吗?

我非常喜欢使用C#5.0异步编程。然而,有几个地方更新旧代码以与TAP模型保持一致给我带来了问题。这是其中之一-我不确定为什么Task在TResult中不是协变的,但在尝试更新协变接口(interface)以从同步模式移动到异步模式时,它给我带来了问题:旧代码:publicinterfaceIInitializable//**outgenericmodifier**{//////Booleantoindicateifclassisready///boolIsInitialized{get;}//////Callsforinstancetobeinitializedusingcurren

c# - C# 4.0 元组是协变的吗

(我会自己检查一下,但我还没有VS2010(还))假设我有2个基本接口(interface):IBaseModelInterfaceIBaseViewInterface还有2个实现这些的接口(interface):ISubModelInterface:IBaseModelInterfaceISubViewInterface:IBaseViewInterface如果我定义一个Tuple我想根据返回Tuple的工厂的结果来设置它.在C#3中,即使子接口(interface)实现了基接口(interface),我也不能这样做。如果我使用IEnumerable,我很确定C#4允许我这样做因为它

c# - 我如何转换到 ObservableCollection<object>

我怎么投fromObservableCollectionintoObservableCollection这对我不起作用(ObservableCollection)myTabItemObservableCollection 最佳答案 你应该这样复制returnnewObservableCollection(myTabItemObservableCollection); 关于c#-我如何转换到ObservableCollection,我们在StackOverflow上找到一个类似的问题:

C# 编译器无法识别正在实现接口(interface)的类

以下代码无法编译(使用VS2010),我不明白为什么。编译器应该能够推断出List与IEnumerable兼容(抱歉找不到更好的词),但不知何故它没有。我在这里缺少什么?interfaceITest{voidTest();}classTestClass:ITest{publicvoidTest(){}}classProgram{staticvoidTest(IEnumerabletests){foreach(vartintests){Console.WriteLine(t);}}staticvoidMain(string[]args){varlst=newList();Test(lst

c# - 为什么 C# 出的泛型类型参数会违反协变?

我不清楚为什么以下代码片段不是协变的?publicinterfaceIResourceColl:IEnumerablewhereT:IResource{intCount{get;}Tthis[intindex]{get;}boolTryGetValue(stringSUID,outTobj);//Errorhere?}Error1Invalidvariance:Thetypeparameter'T'mustbeinvariantlyvalidon'IResourceColl.TryGetValue(string,outT)'.'T'iscovariant.我的界面只在输出位置使用模板参

c# - 为什么 C#/CLR 不支持方法重写协方差/反方差?

关于绕过C#不允许方法返回(和参数)类型被更改为兼容类型的覆盖的限制,有很多问题和答案,但是为什么存在这个限制,在C#编译器中还是在CLR中?如我所见,如果允许协方差/协方差,就没有什么可以破坏的,那么它背后的原因是什么?类似的问题可能会被问到扩大访问参数——例如用公共(public)方法覆盖protected内部方法(Java支持的东西,IIRC) 最佳答案 这个答案不是在谈论C#,但它帮助我更好地理解了问题,也许它会对其他人有所帮助:Whyistherenoparametercontra-varianceforoverridin

c# - 关于 C# 4.0 泛型协变的问题

定义了这个接口(interface):publicinterfaceIInputBoxService{boolShowDialog();TResult{get;}}为什么下面的代码有效:publicclassStringInputBoxService:IInputBoxService{...}...IInputBoxServiceservice=newStringInputBoxService();这不是吗?publicclassIntegerInputBoxService:IInputBoxService{...}...IInputBoxServiceservice=newInteg

c# - 协变/逆变 : how to make the following code compile

更新:以下代码仅在C#4.0(VisualStudio2010)中有意义看来我对协变/逆变有一些误解。谁能告诉我为什么以下代码无法编译?publicclassTestOne{publicIEnumerableMethod(IEnumerablevalues)whereTDerived:TBase{returnvalues;}}编译时:(!!!)publicinterfaceIBase{}publicinterfaceIDerived:IBase{}publicclassTestTwo{publicIEnumerableMethod(IEnumerablevalues){returnva

c# - C# 中的 ref 和 out 参数不能被标记为变体

声明是什么意思?FromhererefandoutparametersinC#andcannotbemarkedasvariant.1)是否意味着以下不能做。publicclassSomeClass:IVariant{publicvirtualRDoSomething(refAargs){returnnull;}}2)或者这是否意味着我不能拥有以下内容。publicdelegateRReader(Aarg,strings);publicstaticvoidAssignReadFromPeonMethodToDelegate(refReaderpReader){pReader=ReadF

c# - Autofac:在一个组合后面隐藏多个逆变实现

我被thisSOquestion触发了关于Autofac的(.NET4.0)协变和逆变支持,现在我正在尝试实现类似的东西,但没有任何运气。我想要实现的是以这样的方式配置Autofac,当我解析一个具体的IEventHandler时(为了使用container.Resolve进行演示,但通常当然使用构造函数注入(inject)),Autofac将返回一个MultipleDispatchEventHandler它包装了所有可从请求的处理程序分配的已注册事件处理程序。换句话说,当我这样写的时候:varhandler=container.GetInstance>();handler.Handl