C# 循环与条件语句详解
C# Switch 语句
使用 switch 语句选择要执行的多个代码块中的一个。
示例:
switch(expression)
{
case x:
// 代码块
break;
case y:
// 代码块
break;
default:
// 代码块
break;
}
它的工作方式如下:
- 评估
switch表达式一次 - 将表达式的值与每个
case的值进行比较 - 如果有匹配,执行关联的代码块
以下示例使用星期几的数字来计算星期几的名称:
示例
int day = 4;
switch (day)
{
case 1:
Console.WriteLine("星期一");
break;
case 2:
Console.WriteLine("星期二");
break;
case 3:
Console.WriteLine("星期三");
break;
case 4:
Console.WriteLine("星期四");
break;
case 5:
Console.WriteLine("星期五");
break;
case 6:
Console.WriteLine("星期六");
break;
case 7:
Console.WriteLine("星期日");
break;
}
// 输出 "星期四"(第 4 天)
break 关键字
当 C# 遇到 break 关键字时,它会跳出 switch 块。
这将停止执行更多 switch 块内部的代码和 case 测试。
当找到匹配并完成任务时,是时候休息一下了。不需要进行更多测试。
break 可以节省大量执行时间,因为它“忽略”了 switch 块中其余代码的执行。
default 关键字
default 关键字是可选的,如果没有 case 匹配,则指定一些代码运行:
示例
int day = 4;
switch (day)
{
case 6:
Console.WriteLine("今天是星期六。");
break;
case 7:
Console.WriteLine("今天是星期日。");
break;
default:
Console.WriteLine("期待周末。");
break;
}
// 输出 "期待周末。"
C# While Loop
循环
循环可以执行一段代码,只要满足指定的条件。
循环很方便,因为它们节省时间、减少错误,并使代码更易读。
C# While 循环
while 循环会在指定条件为 True 的情况下循环执行一段代码块:
示例:
while (condition)
{
// 要执行的代码块
}
在下面的示例中,只要变量(i)小于 5,循环中的代码将一遍又一遍地运行:
示例
int i = 0;
while (i < 5)
{
Console.WriteLine(i);
i++;
}
注意:不要忘记增加条件中使用的变量,否则循环永远不会结束!
Do/While 循环
do/while 循环是 while 循环的变体。这个循环会在检查条件是否为真之前执行一次代码块,然后只要条件为真就重复循环。
语法
do
{
// 要执行的代码块
}
while (condition);
下面的示例使用了 do/while 循环。即使条件为 false,循环也会至少执行一次,因为在测试条件之前执行代码块:
示例
int i = 0;
do
{
Console.WriteLine(i);
i++;
}
while (i < 5);
不要忘记增加条件中使用的变量,否则循环永远不会结束!
C# For Loop
C# For 循环
当你确切地知道要循环执行一段代码多少次时,使用 for 循环而不是 while 循环:
示例:
for (statement 1; statement 2; statement 3)
{
// 要执行的代码块
}
Statement 1 在执行代码块之前执行(一次)。
Statement 2 定义执行代码块的条件。
Statement 3 在执行代码块后执行(每次)。
下面的示例将打印出数字 0 到 4:
示例
for (int i = 0; i < 5; i++)
{
Console.WriteLine(i);
}
示例说明
Statement 1在循环开始之前设置一个变量(int i = 0)。Statement 2定义循环运行的条件(i必须小于5)。如果条件为true,循环将重新开始;如果条件为false,循环将结束。Statement 3在循环中的代码块执行后增加一个值(i++)。
另一个示例
这个示例将只打印出在 0 到 10 之间的偶数值:
示例
for (int i = 0; i <= 10; i = i + 2)
{
Console.WriteLine(i);
}
嵌套循环
也可以将一个循环放在另一个循环内部。这被称为嵌套循环。
"内部循环" 将在 "外部循环" 的每次迭代中执行一次:
示例
// 外部循环
for (int i = 1; i <= 2; ++i)
{
Console.WriteLine("外部: " + i); // 执行 2 次
// 内部循环
for (int j = 1; j <= 3; j++)
{
Console.WriteLine(" 内部: " + j); // 执行 6 次(2 * 3)
}
}
C# For each 循环
还有一个专门用于遍历数组元素的 foreach 循环:
示例:
foreach (type variableName in arrayName)
{
// 要执行的代码块
}
以下示例使用 foreach 循环输出 cars 数组中的所有元素:
示例
string[] cars = {"Volvo", "BMW", "Ford", "Mazda"};
foreach (string i in cars)
{
Console.WriteLine(i);
}
最后
为了方便其他设备和平台的小伙伴观看往期文章:
微信公众号搜索:Let us Coding,关注后即可获取最新文章推送
看完如果觉得有帮助,欢迎 点赞、收藏、关注
C# 循环与条件语句详解的更多相关文章
- JScript中的条件注释详解(转载自网络)
JScript中的条件注释详解-转载 这篇文章主要介绍了JScript中的条件注释详解,本文讲解了@cc_on.@if.@set.@_win32.@_win16.@_mac等条件注释语句及可用于条件编 ...
- mysql基础篇 - SELECT 语句详解
基础篇 - SELECT 语句详解 SELECT语句详解 一.实验简介 SQL 中最常用的 SELECT 语句,用来在表中选取数据,本节实验中将通过一系列的动手操作详细学习 SELEC ...
- T-SQL_select语句详解
select语句执行的过程: 先看查询内容 ==>where条件 ==>[分组条件] ==>[分组搜索条件] ==>内容输出 ==>[是否排序] SQL中SELECT语句 ...
- 【转】MySQL用户管理及SQL语句详解
[转]MySQL用户管理及SQL语句详解 1.1 MySQL用户管理 1.1.1 用户的定义 用户名+主机域 mysql> select user,host,password from mysq ...
- MySQL之SELECT 语句详解
本文参考实验楼的SELECT 语句详解结合自己操作部分而写成. 注意:大多数系统中,SQL语句都是不区分大小写的,但是出于严谨和便于区分保留字和变量名,在书写的时,保留字应大写,而变量名应小写.所谓的 ...
- SQL DELETE 语句详解
SQL DELETE 语句详解 DELETE 语句 DELETE 语句用于删除表中的行. 语法 DELETE FROM 表名称 WHERE 列名称 = 值 Person: LastName Fir ...
- SQL Update 语句详解
SQL Update 语句详解 Update 语句 Update 语句用于修改表中的数据. 语法: UPDATE 表名称 SET 列名称 = 新值 WHERE 列名称 = 某值 Person: L ...
- “全栈2019”Java异常第二十二章:try-with-resources语句详解
难度 初级 学习时间 10分钟 适合人群 零基础 开发语言 Java 开发环境 JDK v11 IntelliJ IDEA v2018.3 文章原文链接 "全栈2019"Java异 ...
- 问题:oracle select into;结果:oracle SELECT INTO 和 INSERT INTO SELECT 两种表复制语句详解
oracle SELECT INTO 和 INSERT INTO SELECT 两种表复制语句详解 (2011-07-08 08:59:47) 转载▼ 标签: it 分类: oracle 我们经常会遇 ...
- C#基础表达式语句详解(上)
本节内容: 1.表达式的定义: 2.各类表达式概览: 3.语句的定义: 4.语句详解: 1.表达式的定义: 1.1什么是表达式: (定义见下图)各类编程语言对表达式的实现不尽相同,但大体上都符合这个定 ...
随机推荐
- Django之第三方平台QQ授权登录的实现
接入指南:https://wiki.connect.qq.com/成为开发者 准备工作 成为开发者 首先要有一个开发者账号,https://connect.qq.com/ 登录后点击用户头像,修改个人 ...
- 【LeetCode链表#7】设计一个链表并实现常见的操作方法
设计链表 题目 力扣题目链接 设计链表的实现.您可以选择使用单链表或双链表.单链表中的节点应该具有两个属性:val 和 next.val 是当前节点的值,next 是指向下一个节点的指针/引用.如果要 ...
- 学会了MySql高级查询让你在工作中游刃有余
一.单元概述 通过本章的学习能够理解MySQL数据库中分组查询的含义,掌握常用分组函数的使用,掌握GROUP BY子句的使用规则,掌握分组后数据结果的条件过滤,掌握SELECT语句执行过程,理解子查询 ...
- 【Azure K8S|AKS】进入AKS的POD中查看文件,例如PVC Volume Mounts使用情况
问题描述 在昨天的文章中,创建了 Disk + PV + PVC + POD 方案(https://www.cnblogs.com/lulight/p/17604441.html),那么如何进入到PO ...
- 【Azure 应用服务】本地Node.js部署上云(Azure App Service for Linux)遇到的三个问题解决之道
问题描述 当本地Node.js(Linux + Node.js + npm + yarn)部署上云,选择 Azure App Service for Linux 环境.但是在部署时,遇见了以下三个问题 ...
- 【Azure 应用服务】访问App Service突然出现 ERR_SSL_PROTOCOL_ERROR错误的解答
问题描述 在中国区的Azure App Service服务中,新创建的站点突然访问出现 " This site can't provide a secure connection,xxxx ...
- 【Azure 事件中心】在Windows系统中使用 kafka-consumer-groups.bat 查看Event Hub中kafka的consumer groups信息
问题描述 使用 Apache Flink 连接支持 Apache Kafka的Azure Event Hub后,由于消费端的Consumer Group是动态创建,在门户页面和Service Bus ...
- 为什么带NOLOCK的查询语句还会造成阻塞
背景 客户反映HIS数据库在11点出现了长时间的阻塞,直到手动KILL掉阻塞的源头.请我们协助分析原因,最终定位到.NET程序中使用的SqlDataReader未正常关闭导致. 现象 登录SQL专家云 ...
- Java 从键盘读入学生成绩 找出最高分 并输出学生等级成绩 * 成绩>=最高分-10 等级为’A‘ * 成绩>=最高分-20 等级为’B‘ * 成绩>=最高分-30 等级为'C' * 其余 等级为’D‘
1 /* 2 * 从键盘读入学生成绩 找出最高分 并输出学生等级成绩 3 * 成绩>=最高分-10 等级为'A' 4 * 成绩>=最高分-20 等级为'B' 5 * 成绩>=最高分- ...
- Linux性能监控(一)-sar
sar是一个非常全面的一个分析工具,对文件的读写,系统调用的使用情况,磁盘IO,CPU相关使用情况,内存使用情况,进程活动等都可以进行有效的分析.sar工具将对系统当前的状态进行取样,然后通过计算数据 ...