我们假设我们有这三个类:
Class BaseClass : System.IComparable
{
[int] $Value
BaseClass([int] $v)
{
$this.Value = $v
}
[int] CompareTo($that)
{
If (-Not($that -is [BaseClass])) {
Throw "Not comparable!!"
}
return $this.Value - $that.Value
}
}
Class SubClassA : BaseClass
{
SubClassA([int] $v) : base($v)
{
}
}
Class SubClassB : BaseClass
{
SubClassB([int] $v) : base($v)
{
}
}
当我们比较BaseClass
:
$base1 = [BaseClass]::new(1)
$base2 = [BaseClass]::new(2)
Write-Output ($base1 -lt $base2)
# Output: True
Write-Output ($base1 -gt $base2)
# Output: False
但是我找不到比较两个子类的两个实例的方法:
$subA1 = [SubClassA]::new(1)
$subB2 = [SubClassB]::new(2)
Write-Output (([BaseClass]$subA1) -lt ([BaseClass]$subB2))
PowerShell无法执行此代码,抛出此错误:
Impossibile confrontare "SubClassA" con "SubClassB".
Errore:
"Impossibile convertire il valore "SubClassB" di tipo "SubClassB" nel tipo "SubClassA"."
从意大利语翻译成英语,此错误消息听起来像是:
Unable to compare "SubClassA" with "SubClassB".
Error:
"Unable to convert the value "SubClassB" of type "SubClassB" to the type "SubClassA"."
为什么会出现这个错误?
我们如何将SubClassA
的实例与SubClassB
的实例进行比较,就像它们是BaseClass
的两个实例一样?
PS:输出$PSVersionTable
:
PSVersion 5.1.17134.1
PSEdition Desktop
PSCompatibleVersions {1.0, 2.0, 3.0, 4.0...}
BuildVersion 10.0.17134.1
CLRVersion 4.0.30319.42000
WSManStackVersion 3.0
PSRemotingProtocolVersion 2.3
SerializationVersion 1.1.0.1
答案 0 :(得分:1)
这种行为确实令人惊讶,我发现您已经开放a GitHub issue进行讨论。
还有一些想法:
PowerShell的运算符通常具有扩展语义,并且通常不应该假设它们在所有情况下都与它们的C#对应物一样工作 - 但是,在这种特殊情况下,它们应该< / em>(见下文)。
-lt
实际上与基类实例一起使用的事实已经指出了一个区别:等效的C#类还需要显式重载{{1} }和<
运算符,以支持使用>
。
接口实现由PowerShell和C#中的派生类继承,因此不需要强制转换为基类以应用<
。
这里似乎发生的事情是,PowerShell盲目地尝试将RHS转换为LHS的类型,而不考虑它们的共享基类。
如果RHS类型直接来自LHS类型(但不是相反),则不会出现问题; e.g:
-lt