Go 语言函数式编程系列教程(十五) —— 流程控制篇:分支语句

栏目: Go · 发布时间: 5年前

内容简介:分支语句会根据传入条件的不同,选择不同的分支代码执行。Go 语言的分支语句和 PHP 类似,只是不需要在每个分支结构中显式通过我们可以通过分支语句改写上篇教程的示例代码:注意这个时候,不能把变量

分支语句会根据传入条件的不同,选择不同的分支代码执行。Go 语言的分支语句和 PHP 类似,只是不需要在每个分支结构中显式通过 break 语句退出:

switch var1 {
    case val1:
        ... 
    case val2:
        ... 
    default:
        ...
}

我们可以通过分支语句改写上篇教程的示例代码:

score := 100
switch {
case score >= 90:
    fmt.Println("Grade: A")
case score >= 80 && score < 90:
    fmt.Println("Grade: B")
case score >= 70 && score < 80:
    fmt.Println("Grade: C")
case score >= 60 && score < 70:
    fmt.Println("Grade: D")
default:
    fmt.Println("Grade: F")
}

注意这个时候,不能把变量 score 放到 switch 关键字后面,否则会报错,只有在与 case 分支值判等的时候,才可以这么做:

score := 100
switch score {
case 90, 100:
    fmt.Println("Grade: A")
case 80:
    fmt.Println("Grade: B")
case 70:
    fmt.Println("Grade: C")
case 60:
case 65:
    fmt.Println("Grade: D")
default:
    fmt.Println("Grade: F")
},

这个时候,只有 score 变量值与给定分支条件值相等时,才会执行对应的分支语句,比如上述代码会打印 Grade: A

Go 语言中,我们可以用逗号分隔不同的分支条件来达到合并分支语句的目的,如 case 90,100 ,而不能像其它语言(如 PHP)那样,通过多个相邻的 case 语句来合并相同的分支语句,比如上面的 case 60case 65 ,因为 case 60 这个分支语句在 Go 语言中会被认为是空语句,直接退出了。

说到这里,我们要介绍下 Go 分支语句中比较有意思的一点,那就是不需要显式通过 break 语句退出某个分支,上一个分支语句代码会在下一个 case 语句出现之前自动退出,如果你想要继续执行后续分支代码,可以通过一个 fallthrough 语句来声明:

score := 60
switch score {
...
case 60:
    fallthrough
case 65:
    fmt.Println("Grade: D")
...
}

这样,就相当于合并 case 60case 65 这两个分支语句了,如果 score 等于 60 的话,这次会打印 Grade: D ,而不是什么也不做。

综上,在 Go 语言中使用 switch...case... 分支语句时,需要注意以下几点:

  • 和条件语句一样,左花括号 { 必须与 switch 处于同一行;
  • 单个 case 中,可以出现多个结果选项(通过逗号分隔);
  • 与其它语言不同,Go 语言不需要用 break 来明确退出一个 case
  • 只有在 case 中明确添加 fallthrough 关键字,才会继续执行紧跟的下一个 case
  • 可以不设定 switch 之后的条件表达式,在这种情况下,整个 switch 结构与多个 if...else... 的逻辑作用等同。

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持 码农网

查看所有标签

猜你喜欢:

本站部分资源来源于网络,本站转载出于传递更多信息之目的,版权归原作者或者来源机构所有,如转载稿涉及版权问题,请联系我们

How to Think About Algorithms

How to Think About Algorithms

Jeff Edmonds / Cambridge University Press / 2008-05-19 / USD 38.99

HOW TO THINK ABOUT ALGORITHMS There are many algorithm texts that provide lots of well-polished code and proofs of correctness. Instead, this one presents insights, notations, and analogies t......一起来看看 《How to Think About Algorithms》 这本书的介绍吧!

JSON 在线解析
JSON 在线解析

在线 JSON 格式化工具

随机密码生成器
随机密码生成器

多种字符组合密码

URL 编码/解码
URL 编码/解码

URL 编码/解码