Bre*_*rry 3 f# named-parameters overload-resolution polly
使用命名参数调用 aDictionary的Add()方法在 F# 中有效。
let d = Dictionary<string, obj>()
d.Add(key = "five", value = 5)
let d2= Dictionary<obj, obj>()
d2.Add(key = "five", value = 5)
d2.Add(key = 5, value = 5)
Run Code Online (Sandbox Code Playgroud)
在 Polly 的Contextclass 中,有一个类似的Add()方法,有 2 个重载:
Add(key: obj, value: obj) : unit
Add(key: string, value: obj) : unit
Run Code Online (Sandbox Code Playgroud)
我可以通过以下所有方式使用它:
let c = Polly.Context()
c.Add("five", 5)
c.Add(5, 5)
c.Add(key = 5, value = 5)
Run Code Online (Sandbox Code Playgroud)
但不是这样,它说它无法在重载之间解析并且需要类型注释。
c.Add(key = "five", value = 5)
Run Code Online (Sandbox Code Playgroud)
为什么会这样,我该如何解决?
编译器无法确定使用哪种方法。这在通常使用 F# 处理 C# 和 OO 风格时更为常见。我不介意,让我在功能上保持诚实。
现在解决问题的最直接方法是使用:
c.Add(key = ("five" :> obj), value = 5)
通过转换它,类型是什么没有歧义,编译器很高兴。
或者,您可以创建一个具有显式类型的函数,这也将有助于编译器弄清楚。如果您经常使用它,我建议这样做:
let addToPolly (ctx:Polly.Context) (k:obj) (v:obj) =
        ctx.Add(k,v)
        ignore()
addToPolly c "five" 5
Run Code Online (Sandbox Code Playgroud)
更新:正如@brett 指出的,我已经推断出答案,但没有明确说明。以下是一些编译器满意的示例。
let pollyAddAsString (ctx:Polly.Context) (k:string) (v:obj) = ctx.Add(key = k, value = v) |> ignore
let pollyAddAsObj (ctx:Polly.Context) (k:obj) (v:obj) = ctx.Add(key = k, value = v) |> ignore
pollyAddAsObj c "five" 5
pollyAddAsString c "five" 5
let (k:string,v:obj) = ("five", 5 :> obj)
let (x:obj,y:obj) = ("five" :> obj, 5 :> obj)
c.Add(key = k, value = v)
c.Add(key = x, value = y)
Run Code Online (Sandbox Code Playgroud)