一、判断语句

if

if可以单独使用,else不能单独使用

int a=;
if(a>)
{
Console.WriteLine("aaa);
}
Console.WriteLine("xxx");//只执行这一句

if...else

//括号里判断真或假,如果为真则执行if里的语句然后跳过else,再执行...
if(a==b)
{ }
//如果if括号为假,那么跳过if{},执行else{},再往下执行
else
{ }
.........

if 括号里一般是“==”判断左右是否相等,或者只有一个变量。

当{}中只有一句代码时,可以省略{}

if(a==b)
;
else ;
........

if..else嵌套

当不是只单纯的判断从二选一的问题时,可能有多种答案就要用到嵌套或switch等语句,反正单个if else是解决不了了,比如判断星期,或根据学生成绩判断优良中差等。

举个例子:

学生考试的成绩按照分数来划分等级

0-59不及格,60-69 差,70-79 中,80-89 良,90-100 优

经常看到有三种嵌套法

1、从if(){}里面嵌套 if....else

首先a是一个0-100区间的整数,在这种情况下

if(a>=)
{   if(a>=)
{ if(a>=&)
{
........里面就不写了
}
else//a>=70且a<80
Console.WriteLine("中");
  }
else//a>=60 且a<70
Console.WriteLine("差");
} else//a<60 Console.WriteLine("不及格");

这方式写代码写着费劲,看代码的人看的蒙圈

在else里嵌套if  else

if(a>&&a<=)
Console.WriteLine("优");
else
{
if(a<)
{
if(a<)
{
..........
} else
Console.WriteLine("良");
}
else
Console.WriteLine("中");
}

1和2一个特点就是代码看着很乱。

3、

if()

else if()

else if()     的方式

if(a>=)
Console.WriteLine("优");
   else if(a>=) //a>=80&&a<90
  Console.WriteLine("良");
     else if(a>=)
  Console.WriteLine("中");
else if(a>=)
   Console.WriteLine("差");
  else if(a<)
  Console.WriteLine("不合格");

这样的写法要比上面两种方法清晰多了

假设

  把 a>=90看做A, a>=80看做B, a>=70看做C,

  则D肯定是在 (!A && !B && !C 的)交集里。

switch

根据swtich传进来的数值,找到到对应的case,比如传进来一个变量 r ,系统会从switch{}里找有没有一个case r:找到后就依次往下执行后面的所有语句,包括最后的default.如果语句遇到break,则跳出本层。

还是以学生成绩举例子

int A=int  (score/);

String B;

switch(A)

{
case :case :
B=“您的成绩为优秀”;
case :
B=“您的成绩为良”;
break;
.....
default
B=“您的成绩不合格”;
}

如果你的成绩是80,也是就找到case 8: ,它会执行B=“您的成绩为良”;这一句,在执行break;跳出switch。

注意:

1、switch 变量的数据类型只能用 bool,byte,short,int,long,char,String这几个。

2、case 标签必须是唯一的。不然两个case 9: 系统无法判断从哪个case 9开始执行。

3、case 标签必须是一个常量表达式。

什么是常量表达式?

常量表达式里面只有常量的式子,比如2+2是常量表达式,如果定义常量a,那么a+2也是常量表达式。

但是如果a是变量,就不是常量表达式了。

4、同时满足几种情况时执行同一段代码 例如上面的case 9和case 10。

二、循环语句

while

while(布尔表达式)
{ }

当while()的表达式为true时,执行{}里的的句子,为false时,不执行{}里的语句直接跳出。

想要让while循环起来的话通常在{}里有一个变量通过自加自减等方式影响着布尔表达式,到达一定条件后使得布尔表示的值为false,从而跳出循环

int i=;
while(i!=)
{
i++;
}

do...while

do..while循环{}会的特点是先执行一次。

int i=
do
{
i++;
}
while(i!=)

 for语句

for(初始化控制变量;布尔表达式;更新控制变量)
{
语句
}
for(int i=;i<;i++)
{
Console.WriteLine(i);
}

首先i进行初始化,然后判断i<0是否成立,如果成立则去执行括号的内容,执行一次{}后执行对变量进行更新执行i++,然后再判断i<0的真假,如果为真继续循环,如果为假结束语句。

注意:

1、初始化只会发生一次。

2、语句要执行一次后,才会执行更新控制变量。

3、更新控制变量后,会重新判断布尔表达式。

for语句的三个部分都可以省略,但是;必须要有,无论怎么省略for循环里的两个;永远都要有。

for(int i=; ;i++)//如果省略布尔表达式,则它默认为true
{ }

多个初始化变量

for中可以提供做个初始化变量

for(int i=,j=;i<;i++,j++)
{
Console.WriteLine(i);
Console.WriteLine(j);
}

for语句的作用域问题

1、如果i是在for()里的初始化控制变量这个位置被初始化,则i的作用范围只能在for里  

for(i=;<;i++) //只能作用在这一个for里
{
Console.WriteLine("i");
}

2、如果有连个for,里面设i,这两个i完全没有联系。

for(i=;<;i++)
{
Console.WriteLine("i");
}
for(i=;<;i+=) //和1里的i没有任何关系,各自在自己的for里起作用
{
Console.WriteLine("i");
}

3、如果要在for外进行输出化,在初始化控制变量的位置进行赋值,则这个变量在for里面外面都有效。

int i ;
for( i=;i<;i++)
{
Console.WriteLine(i);
}
Console.WriteLine(i+);//最后i=12

三、跳转语句

break和continue的区别

break的作用是跳出这一层。如果break语句包含在嵌套循环里,它只跳出最里面的循环。

continue的作用是跳出本次循环,进入到下一次循环。

int i=0;
while(true)
{
i++;
if(i<10)
continue;//直到i=10时才执行else
Console.WriteLine("我想看看世界");//受continue的影响这句话永远执行不到。
else
break;//跳出离它最近的循环,虽然他有层if但if不是循环,所以他会往外找。
}

return退出当前方法,如果方法有返回类型,return必须有返回值。如果方法为void,方法中不能出现return语句

goto 可以直接跳转到程序中用标签指定的另一行

            bool b = true;
if (b)
{
goto lable1;
}
Console.WriteLine("aaa");
lable1:
Console.WriteLine("bbb");
Console.ReadKey();

goto语句有两个限制,不能跳转到想for循环这样的代码块,也不能跳出类,不能退出try catch后面的finally块。

goto不是面向对象的好方式。

  

(7)C#流程控制的更多相关文章

  1. 第10章 Shell编程(4)_流程控制

    5. 流程控制 5.1 if语句 (1)格式: 格式1 格式2 多分支if if [ 条件判断式 ];then #程序 else #程序 fi if [ 条件判断式 ] then #程序 else # ...

  2. Shell命令和流程控制

    Shell命令和流程控制 在shell脚本中可以使用三类命令: 1)Unix 命令: 虽然在shell脚本中可以使用任意的unix命令,但是还是由一些相对更常用的命令.这些命令通常是用来进行文件和文字 ...

  3. PHP基础知识之流程控制的替代语法

    PHP 提供了一些流程控制的替代语法,包括 if,while,for,foreach 和 switch. 替代语法的基本形式是把左花括号({)换成冒号(:),把右花括号(})分别换成 endif;,e ...

  4. Python黑帽编程2.4 流程控制

    Python黑帽编程2.4  流程控制 本节要介绍的是Python编程中和流程控制有关的关键字和相关内容. 2.4.1 if …..else 先上一段代码: #!/usr/bin/python # - ...

  5. 使用yield进行异步流程控制

    现状 目前我们对异步回调的解决方案有这么几种:回调,deferred/promise和事件触发.回调的方式自不必说,需要硬编码调用,而且有可能会出现复杂的嵌套关系,造成"回调黑洞" ...

  6. [Java入门笔记] Java语言基础(四):流程控制

    流程控制指的是在程序运行的过程中控制程序运行走向的方式.主要分为以下几种: 顺序结构 顺序结构,顾名思义,是指程序从上往下逐步顺序执行.中间没有任何的判断和跳转. 分支结构 Java提供两种分支结构: ...

  7. node基础13:异步流程控制

    1.流程控制 因为在node中大部分的api都是异步的,比如说读取文件,如果采用回调函数的形式,很容易造成地狱回调,代码非常不容易进行维护. 因此,为了解决这个问题,有大神写了async这个中间件.极 ...

  8. Shell入门教程:流程控制(1)命令的结束状态

    在Bash Shell中,流程控制命令有2大类:“条件”.“循环”.属于“条件”的有:if.case:属于“循环”的有:for.while.until:命令 select 既属于“条件”,也属于“循环 ...

  9. Oracle中PL/SQL的执行部分和各种流程控制

    Oracle中PL/SQL的执行部分和异常部分 一.PL/SQL的执行部分. 赋值语句. 赋值语句分两种,一种是定义一个变量,然后接收用户的IO赋值:另一种是通过SQL查询结果赋值. 用户赋值举例: ...

  10. swift_简单值 | 元祖 | 流程控制 | 字符串 | 集合

    //: Playground - noun: a place where people can play import Cocoa var str = "Hello, playground& ...

随机推荐

  1. 解决NSTimer循环引用

    NSTimer常见用法 @interface XXClass : NSObject - (void)start; - (void)stop; @end @implementation XXClass ...

  2. maven的一些使用配置!

    1.国外库太慢,更换为国内镜像库在你的maven安装目录下找到conf目录下的setting.xml修改:<mirrors> <id>CN</id> <nam ...

  3. scrapy爬取图片并自定义图片名字

    1   前言 Scrapy使用ImagesPipeline类中函数get_media_requests下载到图片后,默认的图片命名为图片下载链接的哈希值,例如:它的下载链接是http://img.iv ...

  4. 异步fifo的设计(FPGA)

    本文首先对异步 FIFO 设计的重点难点进行分析 最后给出详细代码 一.FIFO简单讲解 FIFO的本质是RAM, 先进先出 重要参数:fifo深度(简单来说就是需要存多少个数据)           ...

  5. Spring Web MVC 笔记

    Spring Web MVC 流程 Dispatcher Servlet 这是一个前端分派 Servlet(前端控制器模式),外部所有的请求都会先到达这里,然后由其将请求分派给其他组件进行实际的处理. ...

  6. Eureka 使用Spring cloud config 管理中心启动

    Config 工程创建之后,Eureka就可以使用Git上的配置启动服务了. Git 服务器的搭建这里就不细说了(自行解决),下面是我上传再git的配置文件: 创建EurekaServer项目(eur ...

  7. 积累: .net里有个线程安全的int+1类

     Interlocked.Increment(ref id); 

  8. 内存cgroup

    内存cgroup的值都是从哪里来的呀 page_counter_charge是增加page_counter的计数, try_charge函数和mem_cgroup_migrate函数是增加普通进程内存 ...

  9. [SP10707]COT2 - Count on a tree II

    题目大意:有一棵$n$个节点的树,第$i$个点有一个颜色$C_i$,$m$组询问,每次问$x->y$的路径上有多少种颜色 题解:树上莫队,把树按欧拉序展开成一条链,令第$i$个节点第一次出现在序 ...

  10. BZOJ 1876 [SDOI2009] SuperGcd | PY好题

    题面就是让你求两个超级大整数,求GCD 题解: 题目本意应该是出题人想考考高精度取膜 但是可以通过一种神奇的Stein算法来做 由J. Stein 1961年提出的Stein算法很好的解决了欧几里德算 ...