高标准的流程控制语句
概述:流程控制语句,可以控制程序的执行流程。
分类:顺序结构 选择结构 循环结构
顺序结构:从上往下,依次执行。
选择结构:(分支结构)
{ if语句 switch语句 }
C 1.0 if语句
格式一 :
if(关系表达式or比较表达式){
语句体
}
执行流程:
先计算比较表达式的值,看其返回值是true还是false
如果是true,就执行语句体;
如果是false,就不执行语句体;
if语句的注意事项:
A:比较表达式无论简单还是复杂,结果必须是boolean类型;
B:if语句控制的语句体如果是一条语句,大括号可以省略;
如果是多条语句,就不能省略。建议永远不要省略!!!
C:if(b != 1);//这里其实是有语句体的,只不过是空语句体。
{ system.out.pringtln};
一般来说,有左大括号就没有分号,有分号就没有左大括号;
格式二 :
if(关系表达式){
语句体1
}else{
语句体2
};
执行流程:
首先计算比较表达式的值,看其返回值是true还是false
如果是true,就执行语句体1;
如果是false,就执行语句体2;
注意:else后面没有比较表达式,只有if后面才有。
由于if语句的第二种格式刚才也完成了三元运算符可以完成的功能。
所以,我们就认为他们可以完成一样的操作。
但是,他们的区别是什么呢?
区别:
三元运算符实现的,if语句都可以实现,反之不能。
什么时候if语句实现不能用三元改进呢?
当if语句控制的操作是一个输出语句的时候就不能。
为什么呢?因为三元运算符是一个运算符,运算符操作完毕后就应该有一个结果,而不是一个输出。
格式三 :
if(比较表达式1){
语句体1;
}else if(比较表达式2){
语句体2;
}
....
}else{
语句体n+1
}
执行流程:
首先计算比较表达式1看其返回值是true还是false,
如果是true,就执行语句体1,if语句结束。
如果是false,接着计算比较表达式2看其返回值是true还是false,
如果是true,就执行语句体2,if语句结束。
如果是false,接着计算比较表达式3看其返回值是true还是false,
...
如果都是false,就执行语句体n+1。
//在做一个程序的基本测试的时候,一定要考虑这样的问题:
//正确数据,错误数据,边界数据。
import java.util.Scanner;
public class PangXie{
public static void main(String[ ]args){
Scanner sc = new Scanner(system.in);
system.out.println("请输入您的成绩");
int score = sc.nextInt();
if(score>=90){
system.out.println("优秀");
}else if(score>=80){
system.out.println("良好");
}else if(score>=70){
system.out.println("一般");
}else if(score>=60){
system.out.println("及格");
}else if(score>=0&&score<60)
system.out.println("不及格");
}else{
system.out.println("您输入的成绩有误");
}
}
if 语句的使用场景:
A:针对表达式是一个boolean类型的判断;
B:针对一个范围的判断;
if语句的嵌套:
C 2.0 switch语句
switch(可支持的某一类型的变量){ case value : //语句 break; //可选 case value : //语句 break; //可选 //你可以有任意数量的case语句 default : //可选 //语句 }
switch case 语句有如下规则:(理解即可)
- switch 语句中的变量类型可以是: byte、short、int 或者 char。从 Java SE 7 开始,switch 支持字符串 String 类型了,同时 case 标签必须为字符串常量或字面量。
- switch 语句可以拥有多个 case 语句。每个 case 后面跟一个要比较的值和冒号。
- case 语句中的值的数据类型必须与变量的数据类型相同,而且只能是常量或者字面常量。
- 当变量的值与 case 语句的值相等时,那么 case 语句之后的语句开始执行,直到 break 语句出现才会跳出 switch 语句。
- 当遇到 break 语句时,switch 语句终止。程序跳转到 switch 语句后面的语句执行。case 语句不必须要包含 break 语句。如果没有 break 语句出现,程序会继续执行下一条 case 语句,直到出现 break 语句。
- switch 语句可以包含一个 default 分支,该分支一般是 switch 语句的最后一个分支(可以在任何位置,但建议在最后一个)。default 在没有 case 语句的值和变量值相等的时候执行。default 分支不需要 break 语句。
switch case 执行时,一定会先进行匹配,匹配成功返回当前 case 的值,再根据是否有 break,判断是否继续输出,或是跳出判断。
任务:键盘输入学生成绩 使用switch case语句 对输入的成绩进行分类
要求:>90 优秀 >80良好 >70一般 >60及格 <60不及格
代码实例演示:
public class Test {
public static void main(String args[]){
//char grade = args[0].charAt(0);
char grade = 'C';
switch(grade){
case 'A' : System.out.println("优秀");
break;
case 'B' :
case 'C' :
System.out.println("良好");
break;
case 'D' :
System.out.println("及格");
break;
case 'F' :
System.out.println("你需要再努力努力");
break;
default :
System.out.println("未知等级");
}
System.out.println("你的等级是 " + grade);
}
}
编译运行结果为:
良好 你的等级是 C