首页 > 其他 > 详细

流程控制之顺数结构和选择结构

时间:2021-06-07 12:15:51      阅读:28      评论:0      收藏:0      [点我收藏+]

# 流程控制之顺数结构

**顺序结构**

java的基本结构就是顺序结构,除非指明,否则就是按照顺序结构一句一句执行

顺序结构是最简单的算法结构

语句与语句之间,框与框之间是按从上到下的顺序进行的,它是由若干个一次执行的处理步骤组成的,**它是任何一个算法都离不开的一种基本算法结构。**

**顺序结构演示**

**演示代码**

```java
package com.gouge.gouge.struct;

public class ShunXuDemo {
public static void main(String[] args) {
System.out.println("Hello1");
System.out.println("Hello2");
System.out.println("Hello3");
System.out.println("Hello4");
System.out.println("Hello5");
}
}

```

# 流程控制之选择结构

**选择结构**

**if单选择结构**

```java
语法:
if(布尔表达式){
//如果布尔值表达式为true将执行的语句
}
```

**if单条件结构练习代码**

```java
package com.gouge.gouge.struct;

import java.util.Scanner;

public class IfDemo01 {
public static void main(String[] args) {
Scanner scanner = new Scanner(System.in);

System.out.println("请输入内容:");
String s = scanner.nextLine();

//equals:判断字符串是否相等
if (s.equals("Hello")){
System.out.println(s);
}
System.out.println("End");

scanner.close();

}
}

```

**if双选择结构**

```java
语法:
if(布尔表达式){
//如果布尔表达式的值为true
}else{
//如果布尔表达式的值为false
}
```

**if双条件结构练习代码**

```java
package com.gouge.gouge.struct;

import java.util.Scanner;

public class IfDemo02 {
public static void main(String[] args) {
//考试分数大于60就是及格,小于60分就是不及格

Scanner scanner = new Scanner(System.in);
System.out.println("请输入成绩:");
int score = scanner.nextInt();

if (score>60){
System.out.println("及格");
}else{
System.out.println("不及格");
}

scanner.close();
}
}

```

**if多选择结构**

```java
语法:
if(布尔表达式 1){
//如果布尔表达式1的值为true执行代码
}else if(布尔表达式 2){
//如果布尔表达式2的值为true执行代码
}else if(布尔表达式 3){
//如果布尔表达式3的值为true执行代码
}else{
//如果以上的布尔表达式都不为true执行代码
}
```

**if多选择结构练习代码**

```java
package com.gouge.gouge.struct;

import java.util.Scanner;

public class IfDemo03 {
public static void main(String[] args) {
//考试分数大于60就是及格,小于60分就是不及格

Scanner scanner = new Scanner(System.in);
System.out.println("请输入成绩:");
int score = scanner.nextInt();

if (score == 100) {
System.out.println("恭喜满分");
} else if (score < 100 && score >= 90) {
System.out.println("A级");
} else if (score < 90 && score >= 80) {
System.out.println("B级");
} else if (score < 80 && score >= 70) {
System.out.println("C级");
} else if (score < 70 && score >= 60) {
System.out.println("D级");
} else if (score < 60 && score >= 0) {
System.out.println("不及格");
} else {
System.out.println("成绩不合法");
}

scanner.close();
}
}
```

***注意事项***

**if 语句至多有1个else语句,else语句在所有的else if语句之后,if语句可以有若干个else if 语句,它们必须在else 语句之前。一旦其中一个else if语句检测为true,其他的else if 以及else 语句都将跳过执行。**

**嵌套的if结构**

```java
语法:
if(布尔表达式 1){
//如果布尔表达式 1的值为true执行代码
if(布尔表达式 2){
//如果布尔表达式 2的值为true执行代码
}
}
```

**Switch多选择结构**

switch case 语句判断一个变量与一系列值中某个值是否相等,每个值称为一个分支。

switch语句中的变量类型可以是:byte、short、int或者char。

从javase 7开始switch支持字符串String类型了,同时case标签必须为字符串常量或者字面量。

jdk7的新特性,表达式结果可以是字符串!!! 字符的本质是数字

反编译:java——class(字节码文件)——反编译(IDEA)

***switch内部执行的语句之后要加break;目的是为了防止case穿透***

```java
语法:
switch(expression){
case value:
//语句
break;//可选
case value:
//语句
break;
//可以有任意数量的case语句
defalut : //可选
//语句
}
```
**switch多选择结构练习代码01**

```java
package com.gouge.gouge.struct;

public class SwitchDemo01 {
public static void main(String[] args) {
// case 穿透(没有break会执行后面的语句) switch 匹配一个具体的值
char grade = ‘A‘;
switch(grade){
case ‘A‘:
System.out.println("优秀");
break; //可选 case 穿透
case ‘B‘:
System.out.println("良好");
break;
case ‘C‘:
System.out.println("及格");
break;
case ‘D‘:
System.out.println("再接再厉");
break;
case ‘E‘:
System.out.println("挂科");
break;
default:
System.out.println("未知等级");
}
}
}
```


**switch多选择结构练习代码02** ——**jdk7新特性***

```java
package com.gouge.gouge.struct;

public class SwitchDemo02 {
public static void main(String[] args) {
String name = "狗哥";

switch(name){
case "苟哥":
System.out.println("是苟哥");
break;
case "狗哥":
System.out.println("是狗哥");
break;
case "狗哥呀":
System.out.println("是狗哥呀");
break;
default:
System.out.println("不是狗哥哎!");
}
}
}

```

**反编译查看源码然后打开如下**

```java
//
// Source code recreated from a .class file by IntelliJ IDEA
// (powered by FernFlower decompiler)
//

package com.gouge.gouge.struct;

public class SwitchDemo02 {
public SwitchDemo02() {
}

public static void main(String[] args) {
String name = "狗哥嘿嘿";
byte var3 = -1;
switch(name.hashCode()) {
case 933102:
if (name.equals("狗哥")) {
var3 = 1;
}
break;
case 1060326:
if (name.equals("苟哥")) {
var3 = 0;
}
break;
case 28947730:
if (name.equals("狗哥呀")) {
var3 = 2;
}
}

switch(var3) {
case 0:
System.out.println("是苟哥");
break;
case 1:
System.out.println("是狗哥");
break;
case 2:
System.out.println("是狗哥呀");
break;
default:
System.out.println("不是狗哥哎!");
}

}
}

```

流程控制之顺数结构和选择结构

原文:https://www.cnblogs.com/gwgbolg/p/14857812.html

(0)
(0)
   
举报
评论 一句话评论(0
关于我们 - 联系我们 - 留言反馈 - 联系我们:wmxa8@hotmail.com
© 2014 bubuko.com 版权所有
打开技术之扣,分享程序人生!