假设我有一个重要的类层次结构:
Tag
ControlFlowTag
IfTag
ForTag
JumpTag
HTMLTag
DivTag
我想列出一个穿插这些和字符串的列表。
let MyList = [tagA, tagB, "some text", tagC]
我以为我可以区分它
type Node =
| Tag of Tag
| String of String
let MyList: list<Node> = [tagA, tagB, "some text", tagC]
但唉,没有它就行不通
let MyList: list<Node> = [Tag tagA, Tag tagB, String "some text", Tag tagC]
显然 Node 中描述的 Tag 和 String 是正交的,并且与现有的 Tag/String 类分开。将鼠标悬停给我类型Node.Tag
和Node.String
,这不是我想要的。
我现在拥有的是一个函数t
,它创建一个StringTag
继承自的函数Tag
,给我
let MyList : list<Tag> = [tagA, tagB, t"some text", tagC]
这非常好,但额外t
增加了视觉噪音。我真正想要的是一个强类型的“两种不同类型的列表”,我可以使用 usingmatch
语句。我认为这是区分联合的重点,但是它们无法使用现有的类型层次结构是一个问题,因为现有的层次结构(在这种情况下Tag
)足够复杂,我认为对该类型子集的完整 OO 继承方法比纯歧视联盟方法
obj
一种选择是在 之前/期间将其列为列表并投射所有内容match
,但这并不是很好。还有其他方法吗?