模式匹配 – 由于Swift的模式匹配中的顺序而导致的意外结果

模式匹配 – 由于Swift的模式匹配中的顺序而导致的意外结果,第1张

概述对不起,“这不应该工作吗?”题.但我无法想出一个更好的方式来表达这一点. enum MyEnum { case A, B, C}let tuple = (MyEnum.C, MyEnum.A) var x: Stringswitch tuple {case (.A, _): x = "(A, something)"case (_, .A): x = " 对不起,“这不应该工作吗?”题.但我无法想出一个更好的方式来表达这一点.

enum MyEnum {    case A,B,C}let tuple = (MyEnum.C,MyEnum.A)    var x: Stringswitch tuple {case (.A,_):    x = "(A,something)"case (_,.A):    x = "(something,A)"case (_,.B):    x = "(something,B)"case (.C,.C):    x = "(C,C)"default:    x = "default"}x // -> "default"

x计算为“default”,表示采用了默认分支.

但是,我期待“(某事,A)”和第二个案例陈述相匹配.根据我的理解(_,.A)应该匹配第一个元组元素中的任何内容,而第二个元素中的.A匹配.

如果我将(_,.A)案例移到顶部,它会按照我的预期进行匹配.其他元组也匹配我期望的位置.

我错过了什么?为什么这不符合第二种情况?

解决方法 此行为已在beta 3中得到纠正.它现在显示(Something,A)无论顺序如何. 总结

以上是内存溢出为你收集整理的模式匹配 – 由于Swift的模式匹配中的顺序而导致的意外结果全部内容,希望文章能够帮你解决模式匹配 – 由于Swift的模式匹配中的顺序而导致的意外结果所遇到的程序开发问题。

如果觉得内存溢出网站内容还不错,欢迎将内存溢出网站推荐给程序员好友。

欢迎分享,转载请注明来源:内存溢出

原文地址: http://outofmemory.cn/web/1017731.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2022-05-23
下一篇 2022-05-23

发表评论

登录后才能评论

评论列表(0条)

保存