在编程语言的类型系统中,协方差和逆变是指从较窄到较宽的类型的排序以及它们在某些情况下的可互换性或等价性(例如参数,泛型和返回类型)
我不明白为什么下面的“x”会转换,但“y”和“z”不会。 var list = new List>(); IEnumerable> x = 列表; 列表> y ...
在C#中可以为类型参数添加方差注释,限制为值类型: 接口 IFoo 其中 T :结构 { 无效 Boo(T x); } 为什么编译器允许这样做,如果
如何将 (ReadOnly)Span<Dog> 转换为 (ReadOnly)Span<Animal> 或反之亦然?
列出变体,因为 Google 没有有用的结果: 我可以将 Span 转换为 Span 吗? 我可以将 Span 转换为 Span 吗? 我可以投射只读...
我正在将一个库移植到网络核心。我们现在有内置的 DI,我想尽可能地使用它。 我的库代理从后端到信号客户端的事件,它包含一个框架来验证...
我最近研究了Typescript中的通用概念。我无法理解“为什么函数与其参数存在逆变?”。我知道: 协方差为 ifT
书中的第二个例子有从动态到对象的方向,对吗?第一个示例具有从字符串到对象的方向,我认为第二个示例将从对象到动态。 为了...
我正在编写一个 C# 程序来计算金融资产的总价值。 每个资产都由资产 ID 表示。有专门用于计算特定资产 ID 的价值的计算器类。
对吗?书中的第二个例子是从动态到对象的方向。也许应该从对象到动态?如果我的假设不正确,请更详细地解释原因。 为了...
今天我正在阅读协变和逆变,我在 Stack Exchange 上看到一篇文章,其中 Jon Skeet 正在解释类级别的不变性。他用了一个水果的例子以及为什么
如果我滥用这个术语,请先发制人道歉,但我能够在打字稿中实现一个我认为类型不安全的接口,例如: 接口点{ x:数字; y:数字; 分布...
不幸的是,Dart(根据设计)缺乏指定不变或逆变类型参数的能力。那么,当我需要他们时,我该如何解决他们缺席的情况呢? 以产品的抽象设置为例...
Python 静态类型提示/检查 Iterable[AnyStr] 与 Iterable[str] 之间的不匹配 |可迭代[字节]
我遇到了这个静态类型提示不匹配(与 Pyright): from __future__ 导入注释 输入 import AnyStr, Iterable def foo(i: Iterable[AnyStr]): 返回我 def bar(i: Iterab...
TL;博士: 为什么可调用泛型类型在 PEP 483 中所述的参数中是逆变的,我对该问题的分析是否准确? (文章底部有分析) 继续...
在 Java 中,协变允许 API 设计者指定一个实例可以泛化为某种类型或该类型的任何子类型。例如: 列表形状=新
假设我有接口和类: 公共接口 ITree {} 公共类树:ITree {} 由于 IEnumerable 是协变的,因此下面的代码行编译成功: IE可枚举 假设我有接口和类: public interface ITree {} public class Tree : ITree {} 由于IEnumerable<T>是协变,所以下面的代码行编译成功: IEnumerable<ITree> trees = new List<Tree>(); 但是当我将它放入泛型方法中时: public void Do<T>() where T : ITree { IEnumerable<ITree> trees = new List<T>(); } 我从编译器中得到编译错误: 错误1无法将类型“System.Collections.Generic.List”隐式转换为“System.Collections.Generic.IEnumerable”。存在显式转换(是否缺少转换?) D:\lab\Lab.General\Lab.General\Program.cs 83 40 Lab.General 为什么协方差在这种情况下不起作用? 这是因为方差仅适用于引用类型(类、接口和委托)。添加一个类约束,它就可以正常编译了: public static void Do<T>() where T : class, ITree 我只是想添加更多示例: 您可以调用 MakeDesignWhereTIsReference 并将 VehicleStruct 传递为 T。但问题是: 引用类型支持协变和逆变,但值类型不支持它们。来自MS 文档 所以我们还需要限制T为引用类型;这可以借助 class 关键字来完成,该关键字添加了我们需要的限制。 public static class TestCovariance { public static void MakeDesignWhereTIsReference<T>() where T : class, IVehicle // pay attention to class restriction { ICollection<IDesign<IVehicle>> list = new List<IDesign<IVehicle>>(); var design = new Design<T>(); list.Add(design); } public static void MakeDesignWhereTIsStruct<T>() where T : struct, IVehicle //This method will throw a cast exception { ICollection<IDesign<IVehicle>> list = new List<IDesign<IVehicle>>(); var design = new Design<T>(); list.Add((IDesign<IVehicle>)design); } } public struct VehicleStruct : IVehicle { } TestCovariance.MakeDesignWhereTIsReference<Ship>(); TestCovariance.MakeDesignWhereTIsStruct<VehicleStruct>();
为什么采用不兼容参数类型的函数类型的联合被认为等同于采用“从不”的函数?
type fnType = ((x: number) => void) | ((x: 字符串) => void); const fn = (innerFn: fnType) => { 内部Fn(“字符串”); } 如果我执行上述操作,打字稿会显示“Argument o...
我不明白为什么编译器会抱怨。以下是基本类型声明: 导出枚举 SvgElementType { 路径=“路径”, 圆=“圆”, } 出口类型
首先我想说的是,我知道这个话题已经在 Stack Overflow 上进行了深入讨论。但我不认为给出的解释提供了有助于保留示例的强有力的故事......
导致编译器或类型检查器(javac)中堆栈溢出的Java片段?
昨天在一个研讨会上,演讲者(Peter Sestoft)展示了一个小型 Java 程序,有 3 个类,具有协方差和逆变的特点。当尝试使用 javac 进行编译时,类型 ch...
我不完全理解泛型中的方差是如何工作的。在下面的代码中,类如下 Any -> Mammals -> Cats。 Any 是超类型,有一个参数从副本中调用