顺序结构
- JAVA的基本结构就是顺序结构,除非特别指明,否则就按照顺序一句一句执行。
- 顺序结构是最简单的算法结构
- 语句与语句之间,框与框之间是按从上到下的顺序进行的,它是由若干个依次执行的处理步骤组成的,它是任何一个算法都离不开的一种基本算法结构。
| package com.L1sy.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单选泽结构
- if双选择结构
- if多选择结构
- 嵌套的if结构
- switch多选择结构
if单选择结构
- 我们很多时候需要去判断一个东西是否可行,然后我们才去执行,这样一个过程在程序中用if语句来表示
- 语法
| package com.L1sy.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(); |
| |
| |
| if (s.equals("Hello")){ |
| System.out.println(s); |
| } |
| System.out.println("End"); |
| scanner.close(); |
| } |
| } |
if双选择结构
- 那现在有个需求,公司要收购一个软件,成功了,给人支付100万元,失败了,自己找人开发。这样的需求用一个if就搞不定,我们需要有两个判断,需要一个双选择结构,所以就有了if-else结构
- 语法:
| package com.L1sy.struct; |
| |
| import java.util.Scanner; |
| |
| public class IfDemo02 { |
| public static void main(String[] args) { |
| |
| 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多选择结构
- 我们发现刚才的代码不符合实际情况,真实的情况还可能存在ABCD,存在区间多级判断。比如90-100就是A,80-90 就是B等等,在生活中我们很多时候的选择也不仅仅只有两个,所以我们需要一个多选择结构来处理这类问题!
- 语法
| if(布尔表达式 1){ |
| |
| }else if(布尔表达式 2){ |
| |
| }else if(布尔表达式 2){ |
| |
| }else { |
| |
| } |
| package com.L1sy.struct; |
| |
| import java.util.Scanner; |
| |
| public class IfDemo03 { |
| public static void main(String[] args) { |
| |
| 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结构
- 使用嵌套的 if...else 语句是合法的。也就是说你可以在另一个 if 或者 else if 语句中使用 if 或者 else if 语句。你可以像 if 语句一样嵌套 else if...else。
- 语法:
| if(布尔表达式 1){ |
| |
| if(布尔表达式 2){ |
| |
| } |
| } |
-
思考?我们需要寻找一个数,在1~100之间
用二分法查找
switch多选择结构
- 多选择结构还有一个实现方式就是switch case 语句。
- switch case 语句判断一个变量与一系列值中某个值是否相等,每个值称为一个分支。
- 看源码
| switch(expression){ |
| case value: |
| |
| break; |
| case value: |
| |
| break; |
| |
| default: |
| |
| } |
- switch 语句中的变量类型可以是:
- byte、short、int或者 char。
- 从 Java SE 7 开始
- switch 支持字符串 String 类型了
- 同时 case 标签必须为字符串常量或字面量。
| package com.L1sy.struct; |
| |
| public class SwitchDemo01 { |
| public static void main(String[] args) { |
| |
| char grade = 'C'; |
| |
| switch (grade){ |
| case 'A': |
| System.out.println("优秀"); |
| break; |
| case 'B': |
| System.out.println("良好"); |
| break; |
| case 'C': |
| System.out.println("及格"); |
| break; |
| case 'D': |
| System.out.println("再接再厉"); |
| break; |
| case 'E': |
| System.out.println("挂科"); |
| default: |
| System.out.println("未知等级"); |
| } |
| } |
| } |
| package com.L1sy.struct; |
| |
| public class SwitchDemo02 { |
| public static void main(String[] args) { |
| String name = "思源"; |
| |
| |
| |
| |
| |
| |
| switch(name){ |
| case "思源": |
| System.out.println("琳"); |
| break; |
| case "琳": |
| System.out.println("思源"); |
| break; |
| default: |
| System.out.println("弄啥嘞!"); |
| } |
| } |
| } |
| |
| |
| |
| |
| |
| package com.L1sy.struct; |
| |
| public class SwitchDemo02 { |
| public SwitchDemo02() { |
| } |
| |
| public static void main(String[] args) { |
| String name = "思源"; |
| byte var3 = -1; |
| switch(name.hashCode()) { |
| case 29747: |
| if (name.equals("琳")) { |
| var3 = 1; |
| } |
| break; |
| case 791059: |
| if (name.equals("思源")) { |
| var3 = 0; |
| } |
| } |
| |
| switch(var3) { |
| case 0: |
| System.out.println("琳"); |
| break; |
| case 1: |
| System.out.println("思源"); |
| break; |
| default: |
| System.out.println("弄啥嘞!"); |
| } |
| |
| } |
| } |
循环结构
while 循环
- 只要布尔表达式为true,循环就会一直执行下去。
- 我们大多数情况是会让循环停止下来的,我们需要一个让表达式失效的方式来结束循环。
- 少部分情况需要循环一直执行,比如服务器的请求响应监听等。
- 循环条件一直为true就会造成无限循环【死循环】,我们正常的业务编程中应该尽量避免死循环。会影响程序性能或者造成程序卡死崩溃!
| package com.L1sy.struct; |
| |
| public class WhileDemo01 { |
| public static void main(String[] args) { |
| |
| |
| |
| int i = 0; |
| |
| while (i<100){ |
| i++; |
| System.out.println(i); |
| } |
| } |
| } |
| package com.L1sy.struct; |
| |
| public class WhileDemo02 { |
| public static void main(String[] args) { |
| |
| while(true){ |
| |
| |
| |
| } |
| } |
| } |
| package com.L1sy.struct; |
| |
| public class WhileDemo3 { |
| public static void main(String[] args) { |
| |
| |
| int i= 0; |
| int sum = 0; |
| |
| while (i<=100){ |
| sum = sum + i; |
| i++; |
| } |
| |
| System.out.println(sum); |
| |
| } |
| } |
do...while 循环
- 对于 while 语句而言,如果不满足条件,则不能进入循环。但有时候我们需要即使不满足条件,也至少执行一次。
- do...while 循环和 while 循环相似,不同的是,do...while 循环至少会执行一次。
| package com.L1sy.struct; |
| |
| public class DoWhileDemo1 { |
| public static void main(String[] args) { |
| int i= 0; |
| int sum = 0; |
| |
| do { |
| sum = sum + i; |
| i++; |
| }while (i<=100); |
| |
| System.out.println(sum); |
| } |
| } |
- While和do-While的区别:
- while先判断后执行。do...while是先执行后判断!
- Do...while总是保证循环体会被至少执行一次!这是他们的主要差别。
| package com.L1sy.struct; |
| |
| public class DoWhileDemo2 { |
| public static void main(String[] args) { |
| int a = 0; |
| while (a<0){ |
| System.out.println(a); |
| a++; |
| } |
| System.out.println("================="); |
| do { |
| System.out.println(a); |
| a++; |
| }while (a<0); |
| } |
| } |
For循环
- 虽然所有循环结构都可以用 while 或者 do...while表示,但 Java 提供了另一种语句——for循环,使一些循环结构变得更加简单。
- for循环语句是支持迭代的一种通用结构。是最有效、最灵活的循环结构。
- for循环执行的次数是在执行前九确定的。语法格式如下:
| package com.L1sy.struct; |
| |
| public class ForDemo01 { |
| public static void main(String[] args) { |
| int a = 1; |
| |
| while (a<=100){ |
| System.out.println(a); |
| a+=2; |
| } |
| |
| System.out.println("while循环结束!"); |
| |
| |
| for (int i=1;i<=100;i++){ |
| System.out.println(i); |
| } |
| |
| System.out.println("for循环结束!"); |
| |
| |
| |
| |
| |
| |
| |
| |
| |
| for (;;) { |
| |
| } |
| } |
| } |
增强for循环
- 这里我们先只是见一面,做个了解,之后数组我们重点使用
- Java5引入了一种主要用于数组或集合的增强 for 循环。
- Java 增强 for 循环语句格式如下:
- 声明语句:声明新的局部变量,该变量的类型必须和数组元素的类型匹配。其作用域限定在循环语句块,其值与此时数组元素的值相等。
- 表达式:表达式是要访问的数组名,或者是返回值为数组的方法。
| package com.L1sy.struct; |
| |
| public class ForDemo05 { |
| public static void main(String[] args) { |
| int[] numbers = {10,20,30,40,50}; |
| |
| for(int i = 0;i<5;i++){ |
| System.out.println(numbers[i]); |
| } |
| System.out.println("======================"); |
| |
| for (int x:numbers){ |
| System.out.println(x); |
| } |
| } |
| } |
打印三角形及Debug
(运行旁边的小瓢虫按钮)
| package com.L1sy.struct; |
| |
| public class TestDemo { |
| public static void main(String[] args) { |
| |
| |
| for (int i = 1; i <= 5; i++) { |
| for (int j = 5; j >= i; j--) { |
| System.out.print(" "); |
| } |
| for (int j = 1; j <= i; j++) { |
| System.out.print("*"); |
| } |
| for (int j = 1; j < i; j++) { |
| System.out.print("*"); |
| } |
| System.out.println(); |
| } |
| |
| } |
| } |
练习
| package com.L1sy.struct; |
| |
| public class ForDemo02 { |
| public static void main(String[] args) { |
| |
| |
| int oddSum = 0; |
| int evenSum = 0; |
| |
| for (int i = 0; i <= 100; i++) { |
| if (i%2!=0){ |
| oddSum+=i; |
| }else { |
| evenSum+=i; |
| } |
| } |
| |
| System.out.println("奇数的和:"+oddSum); |
| System.out.println("偶数的和:"+evenSum); |
| |
| } |
| } |
- 练习2:用while或for循环输出1-1000之间能被5整除的数,并且每行输出3三个
| package com.L1sy.struct; |
| |
| public class ForDemo03 { |
| public static void main(String[] args) { |
| |
| |
| for (int i = 0; i <= 1000; i++) { |
| if (i%5==0){ |
| System.out.print(i+"\t"); |
| } |
| if (i%(5*3)==0){ |
| System.out.println(); |
| |
| } |
| } |
| |
| |
| |
| } |
| } |
| package com.L1sy.struct; |
| |
| public class ForDemo04 { |
| public static void main(String[] args) { |
| |
| |
| |
| |
| |
| |
| |
| |
| |
| |
| |
| |
| |
| |
| for (int i = 1; i < 10; i++) { |
| for (int j = 1; j <= i; j++) { |
| int p = i*j; |
| System.out.print(j+"*"+i+"="+p+"\t"); |
| if (j==i){ |
| System.out.println(); |
| } |
| } |
| |
| } |
| |
| |
| |
| |
| |
| |
| for (int x = 1; x <=9; x++){ |
| for (int y = 1; y <= x;y++){ |
| System.out.print(x+"*"+y+"="+(x*y) + "\t"); |
| } |
| System.out.println(); |
| } |
| } |
| } |
笔记出处——狂神老师
· 10年+ .NET Coder 心语,封装的思维:从隐藏、稳定开始理解其本质意义
· .NET Core 中如何实现缓存的预热?
· 从 HTTP 原因短语缺失研究 HTTP/2 和 HTTP/3 的设计差异
· AI与.NET技术实操系列:向量存储与相似性搜索在 .NET 中的实现
· 基于Microsoft.Extensions.AI核心库实现RAG应用
· 阿里巴巴 QwQ-32B真的超越了 DeepSeek R-1吗?
· 10年+ .NET Coder 心语 ── 封装的思维:从隐藏、稳定开始理解其本质意义
· 【设计模式】告别冗长if-else语句:使用策略模式优化代码结构
· 字符编码:从基础到乱码解决
· 提示词工程——AI应用必不可少的技术