程序语句的三大流程控制结构
1)顺序结构—从上到下依次执行每一条语句
2)选择/分支结构—根据条件选择地执行语句—if/switch
3)循环结构—根据条件反复的执行语句—while/do while/for
选择结构
if语句
1.单分支结构
if(判断条件){
符合条件执行的代码;
}
1)判断条件是一个布尔表达式(关系比较或逻辑表达式)
2)如果符合条件后只有一个语句需要执行,则可以省略大括号,但是为了保证程序结构的清晰,可读性强,强烈建议不要省略
3)if语句的判断条件后不能加分号,否则会影响到执行效果,整个if语句末尾无需加分号
2.双分支结构
if(判断条件){
符合条件执行的代码;
}else{
不符合条件执行的代码;
}
3.多分支结构
if(判断条件1){
符合条件1执行的代码;
}else if(判断条件2){
符合条件2执行的代码;
}else if(判断条件3){
符合条件3执行的代码;
}else{
所有条件都不符合时,执行的代码
}
4.if语句的嵌套使用
if(判断条件1){
if(判断条件2){
语句块1;
}else{
语句块2;
}else{
if(判断条件2){
语句块1;
}else{
语句块2;
}
}
使用Scanner类接收键盘输入的数据
1.Scanner类的使用步骤 Scanner类在java.util包中
1)创建一个Scanner扫描器对象,并传入标准输入对象
Scanner scanner = new Scanner(System.in);
2)调用Scanner对象的nextIInt()方法接收整型数据,按回车表示结束输入
int score = scanner.nextInt();
3)关闭扫描器对象
scanner.close();
2.next()方法和nextLine()方法的区别
【相同点】next()方法和nextLine()方法都能接收字符串数据,都需要最后按回车键结束输入
【不同点】(1)输入数据中有空格时,next()方法只截取空格前的数据并返回,空格后面的输入内容交给后续的读取方法处理
(2)nextLine()方法获取完整的一行输入数据,与数据中有没有空格无关
switch语句
【格式】
switch(变量或表达式){
case 值1:
代码1
[break;]
case 值2:
代码2
[break;]
...
case 值n:
代码n
[break;]
[
default:
默认代码;
break;
]
}
【执行流程】
switch语句一旦匹配上其中的一个case语句,那么就会执行对应的case中的语句代码,如果遇到break语句就会跳出整个switch语句。
如果没有遇到break,则不再判断case,继续执行后续代码(穿透),直到遇到break或者}为止
如果没有匹配到任何的case时,如果有default语句块,则执行,否则直接退出
【注意】
1)switch语句中的变量允许的数据类型
基本类型—byte,short,int,char
包装类型—Byte,Short,Integer,Character
枚举类型—Enum
从JDK7以后,还支持String类型
2)case后面跟的数据必须是常量,不能是变量
3)每个case语句块的排列顺序随意
【优缺点】
【优点1】结构比多重if语句更加清晰,但不要忘记语句块后加break,避免穿透现象
【优点2】由于case后面跟的是常量,常量值在编译时已确定,所以效率比较高
【缺点】只适合判断条件是特定数据值,不适合判断的条件是区间范围的情况