Go语言基础--条件判断(if语句)

if语句它允许程序根据一个或多个条件(通常是布尔表达式)的真假来决定执行哪一段代码。如果条件为真(true),则执行if语句块内的代码;如果条件为假(false),则跳过该代码块,继续执行if语句之后的代码(如果有elseelse if部分,则根据条件判断是否执行这些部分)。

1. if单路径(单选择)

|---|------------------------------|
| | if 条件 { |
| | // 条件为真时执行的路径 |
| | fmt.Println("条件为真,执行此路径") |
| | } |

在这个例子中,只有当条件为真时,才会执行大括号{}内的代码块。

2. if..else双路径(双选择)

|---|------------------------------|
| |
| | if 条件 { |
| | // 条件为真时执行的路径 |
| | fmt.Println("条件为真,执行此路径") |
| | } else { |
| | // 条件为假时执行的路径 |
| | fmt.Println("条件为假,执行此路径") |
| | } |

这个结构提供了两种可能性:如果条件为真,则执行第一个代码块;否则,执行else后面的代码块。

3. if多路径(多选择)

在Go中,通过else if可以实现多路径(或多选择)的条件判断。

|---|---------------------------------|
| | if 条件1 { |
| | // 条件1为真时执行的路径 |
| | fmt.Println("条件1为真,执行此路径") |
| | } else if 条件2 { |
| | // 条件1为假且条件2为真时执行的路径 |
| | fmt.Println("条件2为真,执行此路径") |
| | } else { |
| | // 所有条件都为假时执行的路径 |
| | fmt.Println("所有条件都为假,执行此路径") |
| | } |

这个结构允许你根据多个条件来判断应该执行哪个代码块。

4. if嵌套路径(嵌套选择)

嵌套if结构允许在一个ifelse if块内部再放置一个或多个if语句。

|---|--------------------------------------|
| | if 条件1 { |
| | // 条件1为真时执行的路径 |
| | fmt.Println("条件1为真") |
| | if 条件2 { |
| | // 条件1和条件2都为真时执行的嵌套路径 |
| | fmt.Println("条件1和条件2都为真,执行此嵌套路径") |
| | } |
| | } else { |
| | // 条件1为假时执行的路径 |
| | fmt.Println("条件1为假") |
| | } |

在这个例子中,if 条件2是嵌套在if 条件1内部的,只有当条件1为真时,才会检查条件2。如果条件2也为真,则执行其对应的代码块。

案例:

1. 单路径(单选择)

|---|---------------------------------|
| | package main |
| | import ( |
| | "fmt" |
| | ) |
| | func main() { |
| | score := 85 |
| | // 单路径(单选择) |
| | if score >= 60 { |
| | fmt.Println("恭喜你,及格了!") |
| | } |
| | // 注意:这里不会打印"没及格",因为没有else分支 |
| | } |

2. 双路径(双选择)

|---|----------------------------|
| | package main |
| | import ( |
| | "fmt" |
| | ) |
| | func main() { |
| | score := 55 |
| | // 双路径(双选择) |
| | if score >= 60 { |
| | fmt.Println("恭喜你,及格了!") |
| | } else { |
| | fmt.Println("很遗憾,没及格。") |
| | } |
| | } |

3. 多路径(多选择)

|---|----------------------------|
| | package main |
| | import ( |
| | "fmt" |
| | ) |
| | func main() { |
| | score := 78 |
| | // 多路径(多选择) |
| | if score >= 90 { |
| | fmt.Println("优秀!") |
| | } else if score >= 80 { |
| | fmt.Println("良好!") |
| | } else if score >= 60 { |
| | fmt.Println("及格!") |
| | } else { |
| | fmt.Println("不及格。") |
| | } |
| | } |

4. 嵌套路径(嵌套选择)

|---|----------------------------------------------|
| | package main |
| | import ( |
| | "fmt" |
| | ) |
| | func main() { |
| | score := 88 |
| | attendance := true // 假设这是出勤情况,true表示出勤良好 |
| | // 嵌套路径(嵌套选择) |
| | if score >= 60 { |
| | fmt.Println("及格了,接下来检查出勤情况:") |
| | if attendance { |
| | fmt.Println("出勤良好,有资格获得额外加分。") |
| | } else { |
| | fmt.Println("出勤不佳,请注意改善。") |
| | } |
| | } else { |
| | fmt.Println("很遗憾,没及格。") |
| | } |
| | } |

相关推荐
一灯架构6 小时前
90%的人答错!一文带你彻底搞懂ArrayList
java·后端
小李子呢02116 小时前
前端八股CSS(2)---动画的实现方式
前端·javascript
Y4090017 小时前
【多线程】线程安全(1)
java·开发语言·jvm
布局呆星7 小时前
SpringBoot 基础入门
java·spring boot·spring
风吹迎面入袖凉8 小时前
【Redis】Redisson的可重入锁原理
java·redis
w6100104668 小时前
cka-2026-ConfigMap
java·linux·cka·configmap
GreenTea8 小时前
从 Claw-Code 看 AI 驱动的大型项目开发:2 人 + 10 个自治 Agent 如何产出 48K 行 Rust 代码
前端·人工智能·后端
语戚8 小时前
力扣 968. 监控二叉树 —— 贪心 & 树形 DP 双解法递归 + 非递归全解(Java 实现)
java·算法·leetcode·贪心算法·动态规划·力扣·