Java流程控制*

用户交互Scanner、Scanner进阶使用

用户交互Scanner

​ 之前我们学习的基本语法中我们并没有实现程序和人的交互,但是Java给我们提供了这样一个工具类,我们可以获取用户的输入。java.util.Scanner 是java5的新特征,我们可以通过Scanner类来获取用户的输入

基本语法:

  1. Scanner s = new Scanner(System.in);
  2. //有些代码大家可能不理解,比如这个new,大家目前先不用理解代码的意思,先学会跟着操作,之后我们讲面向对象的时候你就会逐一明白这些代码每一个具体的意思

​ 通过 Scanner 类的 next()nextLine() 方法获取输入的字符串,在读取前我们一般需要使用 hasNext()hasNexLine() 来判断是否还有输入的数据。

​ 下面我们来实践一下加深理解和记忆

使用next方式读取:

  1. package com.xiaodi.operator.scanner;
  2. import java.util.Scanner;
  3. public class Demo01 {
  4. public static void main(String[] args){
  5. //创建一个扫描器对象 用于接收键盘数据
  6. //使用IDEA开发工具输入Scanner之后回车,它就会自动导入这个类import java.util.Scanner;
  7. //我们之前一直用的是System.out是输出;System.in是输入
  8. //这里引用了Scanner数据类型
  9. //通过new Scanner(System.in);接收用户的输入,并且把它封装成了scanner对象
  10. Scanner scanner = new Scanner(System.in);
  11. //输出一行字
  12. System.out.println("使用next()方法接收:");
  13. //判断用户有没有输入字符串
  14. //if语句还没学,if就是如果的意思
  15. //如果scanner这个对象有没有用户输入,(==true不写就是默认上节课讲过,一般新手才会加)有的话就使用执行里面的语句
  16. if (scanner.hasNext()){
  17. //使用next方式接收用,并封装给数据类型为String的str变量
  18. String str = scanner.next();
  19. //输出用户输入的内容
  20. System.out.println("输入的内容为:"+str);
  21. }
  22. //凡是属于IO流的类如果不关闭会一直占用资源,要养成好习惯用完就关
  23. scanner.close();
  24. }
  25. }

​ 我们运行起来之后,他会显示使用next方式读取,然后等待你输入字符串,我输入hello world返回输入的内容为:hello;然后程序结束

​ String str = scanner.next();这句代码执行完程序会等待用户输入完毕,如果你没去输入数据那么程序就会一直卡在那

​ 但是有没有发现我们输入的hello world它只输出了一个hello

刚才我们使用的是next(),现在我们使用nextLine()试一下:

  1. package com.xiaodi.operator.scanner;
  2. import java.util.Scanner;
  3. public class Demo02 {
  4. public static void main(String[] args) {
  5. Scanner scanner = new Scanner(System.in);
  6. System.out.println("使用nextLine()方法读取:");
  7. if (scanner.hasNext()) {
  8. //使用nextLine()方式读取,并封装给数据类型为String的str变量
  9. String str = scanner.nextLine();
  10. System.out.println("输入的内容为:"+str);
  11. }
  12. scanner.close();
  13. }
  14. }

这次输入hello world,返回的也是hello world

那我们来看一下next()和nextLine()两种接收用户输入到底有上面区别

next():

  1. 一定要读取到有效字符后才可以结束输入。
  2. 对输入有效符之前遇到的空白,next()方法会自动去掉

​ 例如我输入: hello;则返回:hello

  1. 只有输入有效字符后才将其后面输入的空白作为分隔符或结束符

  2. next() 不能读取带有空格的字符串

nextLine():

  1. 以Enter为结束符,也就说 nextLine()方法返回的是输入回车之前的所有字符
  2. 可以获得空白

我们还没有学习到if上面的代码看起来会比较复杂,我下面写一个不用if语句和判断用户输入方法的的代码,让大家自己分析,我就不写注释了

  1. package com.xiaodi.operator.scanner;
  2. import java.util.Scanner;
  3. public class Demo03 {
  4. public static void main(String[] args) {
  5. Scanner scanner = new Scanner(System.in);
  6. System.out.println("请输入数据:");
  7. String str = scanner.nextLine();
  8. System.out.println("输入的内容为:"+str);
  9. scanner.close();
  10. }
  11. }

以上内容请务必掌握!!!

Scanner进阶使用

万一我们需要用户输入指定类型的数据,那该怎么判断用户输入的是否是我们指令类型的数据

我们在IDEA定义好scanner对象后;输入scanner.后会跳出很多方法出来

比如scanner.hasNextInt() :这样就是判断是否输入的是Int类型;这样我们就能配合if...else...语句来使用;if...else...就是如果就否则就的意思。

读取数据的方法也要变成scanner.nextInt()

下面我们来演示一下

  1. package com.xiaodi.operator.scanner;
  2. import java.util.Scanner;
  3. public class Demo04 {
  4. public static void main(String[] args) {
  5. Scanner scanner = new Scanner(System.in);
  6. int i = 0;
  7. float f = 0.0F;
  8. //提示用户输入
  9. System.out.println("请输入数据:");
  10. //使用hasNextInt()方法判读用户输入的数据是否为Int类型
  11. if (scanner.hasNextInt()) {
  12. //使用nextInt()方法读取Int数据,并赋值给i(这里因为i我们上面已经定义了所以不用在指定类型)
  13. i = scanner.nextInt();
  14. System.out.println("输入的数据为:"+i);
  15. }else {
  16. System.out.println("请输入整数类型的数据!");
  17. String a = scanner.nextLine();
  18. }
  19. //提示用户输入
  20. System.out.println("请输入数据:");
  21. //使用hasNextFloat()方法判读用户输入的数据是否为Float类型
  22. if (scanner.hasNextFloat()) {
  23. //使用nextFloat()方法读取float数据,并赋值给f(这里因为f我们上面已经定义了所以不用在指定类型)
  24. f = scanner.nextFloat();
  25. System.out.println("输入的数据为:"+f);
  26. }else {
  27. System.out.println("请输入小数类型的数据!");
  28. }
  29. scanner.close();
  30. }
  31. }

运行的结果为:

第一种情况:

​ 请输入数据:

​ 1

​ 输入的数据为:1

​ 请输入数据:

​ 1.2

​ 输入的数据为:1.2

第二种情况

请输入数据:

xiaodi

请输入整数类型的数据!

请输入数据:

xiaodi

请输入小数类型的数据!

有没有发现我在第一个if...else...语句中的else中加了一行代码

  1. String a = scanner.nextLine();
  2. 你不加这行代码的话,你运行起来,你第一个数据输入错误了,它会直接将第一个数据拿到第二次做判断,导致你第二次不能输入数据。(但是有的地方会有需要这种情况,但是我们这里测试的话就不用了)

案例:

​ 我们可以输入多个数字,并求其总和与平均数,每输入一个数字用回车确认,通过输入输入非数字来结束输入并输出执行结果

  1. package com.xiaodi.operator.scanner;
  2. import java.util.Scanner;
  3. public class Demo05 {
  4. public static void main(String[] args) {
  5. Scanner scanner = new Scanner(System.in);
  6. //和,有可能会输入小数,所以使用double类型
  7. double sum = 0.0;
  8. //个数,因为最后要求平均值,平均值就是和除以个数
  9. int m = 0;
  10. //使用while循,判断是否输入数字,如果是就一直循环获取用户输入,如果不是则退出循环
  11. while (scanner.hasNextDouble()) {
  12. //获取用户输入,并赋值给i
  13. double i = scanner.nextDouble();
  14. //把和加上获取的输入
  15. sum = sum + i;
  16. //个数加1
  17. m = m + 1;//m++
  18. System.out.println("您输入了第"+m+"个数据当前的总和为:"+sum);
  19. }
  20. //输出总和和平均数
  21. System.out.println("您输入的数据的总和为:"+sum);
  22. System.out.println("您输入的数据的平均数为:"+(sum / m));
  23. scanner.close();
  24. }
  25. }

运行结果:

​ 10.5

​ 您输入了第1个数据当前的总和为:10.5

​ 19.5

​ 您输入了第2个数据当前的总和为:30.0

​ 30

​ 您输入了第3个数据当前的总和为:60.0

​ 40

​ 您输入了第4个数据当前的总和为:100.0

​ x

​ 您输入的数据的总和为:100.0

​ 您输入的数据的平均数为:25.0

其中while循环还不懂没关系,你先跟着我的代码写一遍,等一下学到你再回来看一下,你就会恍然大悟,原来是这个样子的!


顺序结构

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

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

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


选择结构*

if选择结构

if单选择结构

​ 我们很多时候需要去判断一个东西是否可行,然后我们才去执行,这样一个过程在程序中用if语句来表示

语法:

  1. if (布尔表达式) {
  2. //如果布尔表达式为true将执行的语句,如果为false则跳过if语句
  3. }

演示:

  1. package com.xiaodi.operator.struct;
  2. import java.util.Scanner;
  3. public class Demo01 {
  4. public static void main(String[] args) {
  5. Scanner scanner = new Scanner(System.in);
  6. System.out.println("请输入内容:");
  7. String s = scanner.nextLine();
  8. //equals:判断字符串是否一致的方法,是字符串的一种方法
  9. if (s.equals("Hello")) {
  10. System.out.println(s);
  11. }
  12. System.out.println("End");
  13. scanner.close();
  14. }
  15. }

第一次输入Hello则执行if语句结果如下:

​ 请输入内容:

​ Hello

​ Hello

​ End

第二次输入XiaoDi则跳过if语句结果如下:

​ 请输入内容:

​ XiaoDi

​ End

if双选择结构

​ 那现在有一个需求,学校要一个输入分数来判定学生成绩是否及格的程序,>=60分为及格,<60分为不及格。这样的需求用一个if就搞不定了,我们需要有两个判断,需要一个双选择结构,所以就要使用if-else结构

语法:

  1. if (布尔表达式) {
  2. //如果布尔表达式值为true执行的代码
  3. }else {
  4. //如果布尔表达式值为false执行的代码
  5. }

演示:

  1. package com.xiaodi.operator.struct;
  2. import java.util.Scanner;
  3. public class Demo02 {
  4. public static void main(String[] args) {
  5. Scanner scanner = new Scanner(System.in);
  6. System.out.println("请输入你的分数:");
  7. int score = scanner.nextInt();
  8. if (score>=60) {
  9. System.out.println("及格");
  10. }else {
  11. System.out.println("不及格");
  12. }
  13. scanner.close();
  14. }
  15. }

第一个同学考了10分(走了else的分支)结果如下:

​ 请输入你的分数:

​ 10

​ 不及格

第二个同学考了90分(走了if的分支)结果如下:

​ 请输入你的分数:

​ 90

​ 及格

if多选择结构

​ 我们发现刚才的代码不符合实际情况,真实的情况还可能存在SABCD,存在区间多级判断。比如90-100就是S,80-90就是B..等等,在生活中我们很多时候的选择也不仅仅只有两个,所以我们需要一个多选择结构来处理这类问题!

语法:

  1. if (布尔表达式1){
  2. //如果布尔表达式1的值为true执行的代码
  3. }else if {
  4. //如果布尔表达式2的值为true执行的代码
  5. }else if {
  6. //如果布尔表达式2的值为true执行的代码
  7. }else {
  8. //如果以上布尔表达式都不为true执行的代码
  9. }

演示:

  1. package com.xiaodi.operator.struct;
  2. import java.util.Scanner;
  3. import java.util.SortedMap;
  4. public class Demo03 {
  5. public static void main(String[] args) {
  6. Scanner scanner = new Scanner(System.in);
  7. System.out.println("请输入你的成绩:");
  8. int score = scanner.nextInt();
  9. if (score<40 && score>=0) {
  10. System.out.println("你的成绩评级为:D");
  11. }else if (score>=40 && score<60) {
  12. System.out.println("你的成绩评级为:C");
  13. }else if (score>=60 && score<80) {
  14. System.out.println("你的成绩评级为:B");
  15. }else if (score>=80 && score<90) {
  16. System.out.println("你的成绩评级为:A");
  17. }else if (score>=90 && score<=100) {
  18. System.out.println("你的成绩评级为:S");
  19. }else {
  20. System.out.println("本次评级的分数为0-100,请输入正确的成绩");
  21. }
  22. scanner.close();
  23. }
  24. }

太多分支,可以自己执行看看!我这里就不演示执行结果了!会使文章看起来怪怪的

嵌套的if结构

使用嵌套的if...else语句是合法的。也就是你可以在另一个if或 else if语句中使用if或else if语句,你可以像if语句一样嵌套else if...else

语法:

  1. if (布尔表达式1) {
  2. //如果布尔表达式1的值为true执行的代码
  3. if (布尔表达式2) {
  4. //如果布尔表达式2的值为true执行的代码
  5. }
  6. }

有时候我们在解决一些问题的时候,可以缩小操作范围,它可以通过层级来判断,提高效率

​ 比如我们现在有一个需求:要查找1-100之间这样的一个数字,这样的话是比较麻烦的;

​ 我们最笨的方法就是将用户输入的数字去1-100之间一个一个的对比,但是万一他输入了100,那程序就要对比到100才能成功,这样就会花费更多的资源和时间;我们就可以用if嵌套来判断,把这个100分成1-50,50-100去判断用户输入的值在哪个里面,或者分成更多份去判断;

我们生活在这个大数据时代,我们应该不断去思考如何提高我们程序的效率,或许哪一天你就想出来了能够提高效率的算法那你将在程序的历史上留下一些痕迹了!

记住一点:我们流程控制语句都可以相互嵌套而互不影响

Switch选择结构

​ 多选择结构还有一个实现方法就是switch case语句。

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

语法:

  1. switch(expression) {
  2. case value :
  3. //语句
  4. break; //可选
  5. case value :
  6. //语句
  7. break //可选
  8. default : //可选
  9. 语句
  10. }

switch语句中的变量类型可以是:

​ byte、short、int或char

从Java SE7开始,switch支持String类型了

​ 同时case标签必须在为字符串常量或字面量

演示:

  1. package com.xiaodi.operator.struct;
  2. public class SwitchDemo01 {
  3. public static void main(String[] args) {
  4. char grade = 'C';
  5. switch (grade) {
  6. case 'A' :
  7. System.out.println("优秀");
  8. break; //可选
  9. case 'B' :
  10. System.out.println("良好");
  11. case 'C' :
  12. System.out.println("及格");
  13. case 'D' :
  14. System.out.println("再接再厉");
  15. case 'E' :
  16. System.out.println("挂科");
  17. }
  18. }
  19. }

当grade为C时运行如下:

​ 及格

​ 再接再厉

​ 挂科

当grade为A时运行如下:

​ 优秀

为什么会这样,我说过这个break是可选的,如果不写break他就会执行匹配到的分支以及后面的分支直到遇到break,如果没遇到,就会直接执行到最后;这种现象叫做case穿透;(所以要养成一个好习惯,写完每一个case后面都应该加一个break(除非特殊需求))

我们还可以来一个default

  1. package com.xiaodi.operator.struct;
  2. public class SwitchDemo01 {
  3. public static void main(String[] args) {
  4. char grade = 'F';
  5. switch (grade) {
  6. case 'A' :
  7. System.out.println("优秀");
  8. break; //可选
  9. case 'B' :
  10. System.out.println("良好");
  11. break; //可选
  12. case 'C' :
  13. System.out.println("及格");
  14. break; //可选
  15. case 'D' :
  16. System.out.println("再接再厉");
  17. break; //可选
  18. case 'E' :
  19. System.out.println("挂科");
  20. break; //可选
  21. default :
  22. System.out.println("未知等级");
  23. }
  24. }
  25. }

当grade不等于任何一个case的时候就会执行default分支;

​ 跟if比起来switch是有一些好处的,它在执行case语句的时候会先匹配,匹配成功就会返回当前case的值,然后再根据它是否有break判断是否继续输出。if是判断匹配区间,而switch是匹配一个具体的值!

接下来演示JDL7开始才支持的字符串类型:

  1. package com.xiaodi.operator.struct;
  2. public class SwitchDemo02 {
  3. public static void main(String[] args) {
  4. String name = "晓迪";
  5. switch (name) {
  6. case "小迪" :
  7. System.out.println("小迪");
  8. break;
  9. case "晓迪" :
  10. System.out.println("晓迪");
  11. break;
  12. default :
  13. System.out.println("神马东西??");
  14. }
  15. }
  16. }

运行结果为:晓迪

还记不记得我之前讲过字符的本质还是数字,给大家讲一个东西反编译

什么叫反编译:比如.java文件编译成.class文件,这个class文件叫做字节码文件是人类看不懂的,我们要看懂就要进行反编译

反编译教程:

​ 使用IDEA,点开享目结构(File-->Project Structure),就能看到Compiler output,将地址复制到文件管理器,打开找对对应需要反编译的文件,你可以使用notepad++打开看一下,你会发现看不懂,没事我也看不懂。

​ 在IDEA文件夹那边右键,选择Open ln,再选择Explorer打开对应文件夹,把class文件复制进去,在IDEA双击这个字节码文件,选择Accept,这个就是反编译之后的

  1. //
  2. // Source code recreated from a .class file by IntelliJ IDEA
  3. // (powered by FernFlower decompiler)
  4. //
  5. package com.xiaodi.operator.struct;
  6. public class SwitchDemo02 {
  7. public SwitchDemo02() {
  8. }
  9. public static void main(String[] args) {
  10. String name = "晓迪";
  11. byte var3 = -1;
  12. switch(name.hashCode()) {
  13. case 767419:
  14. if (name.equals("小迪")) {
  15. var3 = 0;
  16. }
  17. break;
  18. case 848887:
  19. if (name.equals("晓迪")) {
  20. var3 = 1;
  21. }
  22. }
  23. switch(var3) {
  24. case 0:
  25. System.out.println("小迪");
  26. break;
  27. case 1:
  28. System.out.println("晓迪");
  29. break;
  30. default:
  31. System.out.println("神马东西??");
  32. }
  33. }
  34. }

​ 你会发现 switch (name) {} 变成了 switch(name.hashCode()) {} ; case "晓迪" : 变成了 case 848887: ,也就是说它进行编译之后是通过hashCode()进行判断的,什么是hashCode(),你现在可以理解为每一个对象都有一个hashCode,它是通过一些特定算法生成的,而我们case后面的字符串中文都会有一个自己对应的hash值,然后它就判断这个hash值是否跟name的hash值相同,这就是JDK7新特性的原理


循环结构*

while 循环

while是最基本的循环,她的结构为:

  1. while (布尔表达式) {
  2. //循环内容
  3. }
  • 只要布尔表达式为 true ,循环就会一直执行下去。
  • 我们大多数情况会让循环停止下来,我们需要一个让表达式失效的方式来结束循环
  • 少部分情况需要循环一直执行,比如服务器的请求响应监听等
  • 循环条件一直为true就会造成无限循环【死循环】,我们正常的业务编程中应该尽量避免死循环。会影响程序性能或者造成程序卡死崩溃!

演示输出1-100:

  1. package com.xiaodi.operator.struct;
  2. public class WhileDemo01 {
  3. public static void main(String[] args) {
  4. int i = 0;
  5. while (i<100) {
  6. i++;//i = i + 1;
  7. System.out.println(i);
  8. }
  9. }
  10. }

运行会输出1-100

演示死循环:

  1. package com.xiaodi.operator.struct;
  2. public class WhileDemo02 {
  3. public static void main(String[] args) {
  4. while (true) {
  5. System.out.println(1);
  6. }
  7. }
  8. }

运行会无限输出1 直到程序崩溃

演示:计算1+2+3+...+100=?

  1. package com.xiaodi.operator.struct;
  2. public class WhileDemo03 {
  3. public static void main(String[] args) {
  4. int i = 0;
  5. int sum = 0;
  6. while (i<100) {
  7. i++;
  8. sum = sum + i;
  9. }
  10. System.out.println(sum);
  11. }
  12. }

结果5050

其中while循环还能像下面这样写自己思考一下有什么不同

  1. while (i<=100) {
  2. sum = sum + i;
  3. i++;
  4. }

do..while 循环

  • 对于 while 循环而言,如果不满足条件,则不能进入循环。但有时候我们需要即使不满足条件,也至少执行一次。
  • do...while 循环和 while 循环相似,不同的是,do...while 循环至少会执行一次。

语法:

  1. do {
  2. //代码语句
  3. }while (布尔表达式);

同样是1+2+3...+100,看看DoWhile是怎么实现的吧!

  1. package com.xiaodi.operator.struct;
  2. public class DoWhileDemo01 {
  3. public static void main(String[] args) {
  4. int i = 0;
  5. int sum = 0;
  6. do {
  7. i++;
  8. sum = sum + i;
  9. }while (i<100);
  10. System.out.println(sum);
  11. }
  12. }

While和do-While的区别:

  • while先判断后执行。dowhile是先执行后判断!
  • Do...while总是保证循环体会被至少执行一次!这是他们的主要差别。

演示:两者区别

  1. package com.xiaodi.operator.struct;
  2. public class DoWhileDemo02 {
  3. public static void main(String[] args) {
  4. int a = 0;
  5. int sum = 0;
  6. while (a<0) {
  7. System.out.println(a);
  8. a++;
  9. }
  10. System.out.println("===========");
  11. do {
  12. System.out.println(a);
  13. a++;
  14. }while (a<0);
  15. }
  16. }

输出结果为:

​ ===========

​ 0


for 循环

  • 虽然所有的循环结构都可以用while或者do...while表示,但java提供了另一种语句 for循环,使一些循环结构变得更加简单

  • for循环语句是支持迭代的一种通用结构,是最有效、最灵活的循环结构

  • 在IDEA直接输入100.for然后回车能快捷生成

  • for循环执行的次数是在执行前就确定的。语法格式如下:

  1. for (初始化;布尔表达式;迭代) {
  2. //代码语句
  3. }

实例:

  1. package com.xiaodi.operator.struct;
  2. public class ForDemo01 {
  3. public static void main(String[] args) {
  4. int a = 1;//初始化条件
  5. while (a<=100) { //布尔表达式
  6. System.out.println(a);//输出a
  7. a+=2; //迭代
  8. }
  9. System.out.println("while循环结束");
  10. //初始化;布尔表达式;迭代
  11. for (int i=0;i<=100;i++) {
  12. System.out.println(i);
  13. }
  14. System.out.println("For循环结束");
  15. }
  16. }

for的死循环

  1. package com.xiaodi.operator.struct;
  2. public class ForDemo02 {
  3. public static void main(String[] args) {
  4. for (;;) {
  5. }
  6. }
  7. }

练习1:计算0-100之间的基数和偶数的和;

  1. package com.xiaodi.operator.struct;
  2. public class ForDemo03 {
  3. public static void main(String[] args) {
  4. int oddSum = 0;
  5. int evenSum = 0;
  6. for (int i=0;i<100;i++) {
  7. if (i%2!=0) { //奇数
  8. oddSum+=i;
  9. }else { //偶数
  10. evenSum+=i;
  11. }
  12. }
  13. System.out.println("0-100之间的奇数和:"+oddSum);
  14. System.out.println("0-100之间的偶数和:"+evenSum);
  15. }
  16. }

练习2:用while或for循环输出1-1000之间能被5整除的数,并且每行输出3个

第一种方法:

  1. package com.xiaodi.operator.struct;
  2. public class ForDemo04 {
  3. public static void main(String[] args) {
  4. for (int i=0;i<1000;i++) {
  5. if (i%5==0) {
  6. System.out.print(i+"\t");
  7. }
  8. if (i%(3*5)==0) {
  9. System.out.println();
  10. //System.out.print("\n");
  11. }
  12. }
  13. //println 输出完会换行
  14. //print 输出完不会换行
  15. }
  16. }

第二种方法:

  1. package com.xiaodi.operator.struct;
  2. public class ForDemo04_1 {
  3. public static void main(String[] args) {
  4. for (int i = 0; i < 1000; i+=5) {
  5. System.out.print(i+"\t");
  6. if (i%(3*5)==0) {
  7. System.out.println();
  8. }
  9. }
  10. }
  11. }

​ 这些练习不一定要用我写的方法才能实现,大家也可以多思考,主要思路肯定是循环

至于我为什么这题要写两种方法呢?

  • 第一种使用的是i++每次只+1,需要循环1000次,第二种使用的是直接+5,只需循环200次即可,如果遇到非常大的数据时可以减少%75的资源,这是一件很好的事情哈

我们可以在不影响程序正常工作的条件下,减少程序运行所需资源

练习3:打印99乘法表

  1. package com.xiaodi.operator.struct;
  2. //效果如下
  3. //1*1=1
  4. //1*2=2 2*2=4
  5. //1*3=3 2*3=6 3*3=9
  6. //1*4=4 2*4=8 3*4=12 4*4=16
  7. //1*5=5 2*5=10 3*5=15 4*5=20 5*5=25
  8. //1*6=6 2*6=12 3*6=18 4*6=24 5*6=30 6*6=36
  9. //1*7=7 2*7=14 3*7=21 4*7=28 5*7=35 6*7=42 7*7=49
  10. //1*8=8 2*8=16 3*8=24 4*8=32 5*8=40 6*8=48 7*8=56 8*8=64
  11. //1*9=9 2*9=18 3*9=27 4*9=36 5*9=45 6*9=54 7*9=63 8*9=72 9*9=81
  12. public class ForDemo05 {
  13. public static void main(String[] args) {
  14. //1、我们先打印第一列,这个大家应该都会
  15. //for (int i = 1; i <= 9; i++) {System.out.println("1*"+i+"="+(1*i));}
  16. //2、我们把固定的1再用一个循环包起来
  17. //使用for (int j = 1; j <= 9; j++) {}把上面的包起来 把固定的1换成循环的j
  18. //3、去掉重复项,
  19. //i<=j
  20. //4、调整样式
  21. //使用print使其不换行 间隔用"\t"
  22. //里面的循环每次完成一次则输出一次换行 System.out.println();
  23. for (int j = 1; j <= 9; j++) {
  24. for (int i = 1; i <= j; i++) {
  25. System.out.print(i+"x"+j+"="+(j*i) + "\t");
  26. }
  27. System.out.println();
  28. }
  29. }
  30. }

​ 这道题主要学习思路,学会把一个大问题拆分成若干个小问题,逐一攻破!,这也是我们以后开发项目的一个基本思路!


增强型for循环

  • 这里我们先只是先见一面,做个了解,之后数组我们重点使用
  • Java5引入了一种主要用于数组或集合的增强型 for循环。

语法:

  1. for (声明语句 : 表达式) {
  2. //代码句子
  3. }

声明语句:声明新的局部变量,该变量的类型必须和数组元素的类型匹配,其作用域限定在循环语句块,其值与此时数组元素的值相等

表达式:表达式是要访问的数组名,或者是返回值为数组的方法。

演示:

  1. package com.xiaodi.operator.struct;
  2. public class ForDemo06 {
  3. public static void main(String[] args) {
  4. int[] numbers = {10, 20, 30, 40, 50}; //定义了一个数组
  5. //遍历数组的元素
  6. for (int x:numbers) {
  7. System.out.println(x);
  8. }
  9. }
  10. }

分析:把numbers这个数组每一项遍历出来,赋值给int x,每次循环x就从numbers中取值

我们用普通for循环演示一下 上面的操作,上面使用的增量型for循环就是用来简化下面的操作,核心原理是一样的,大家简单理解一下

  1. package com.xiaodi.operator.struct;
  2. public class ForDemo07 {
  3. public static void main(String[] args) {
  4. int[] numbers = {10, 20, 30, 40, 50};
  5. for (int i = 0;i<5;i++) {
  6. System.out.println(numbers[i]);
  7. }
  8. }
  9. }

现在能理解当然是最好的了,不理解也没关系,我们现在只是让大家知道一下我们以后会学一个这样简化的东西!不理解不必深究!


break &continue*

  • break在任何循环语句的主体部分,均可用break控制循环的流程。break用于强行退出循环,不执行循环中剩余的语句。(break语句也在switch'语句中使用)

演示:

  1. package com.xiaodi.operator.struct;
  2. public class BreakDemo01 {
  3. public static void main(String[] args) {
  4. int i = 0;
  5. while (i<100) {
  6. i++;
  7. System.out.println(i);
  8. if (i==30) { //如果i等于30的时候,则跳出循环体
  9. break;
  10. }
  11. }
  12. System.out.println("123"); //证明break只是跳出循环体
  13. }
  14. }

break只是跳出循环,程序还会继续执行。

  • continue 语句用在循环语句体中,用于终止某次循环过程,即跳过循环体中尚未执行的语句,接着进行下一次是否执行循环的判定。

演示:

  1. package com.xiaodi.operator.struct;
  2. public class ContinueDemo01 {
  3. public static void main(String[] args) {
  4. int i = 0;
  5. while (i<100) {
  6. i++;
  7. if ((i%10)==0) { //如果i能被10整除,则输出换行,然后跳过当前这次循环
  8. System.out.println();
  9. continue;
  10. }
  11. System.out.print(i+"\t");
  12. }
  13. }
  14. }

通过上面的演示,break可以理解为,我不干了;continue可以理解为,我不干了第二天又怂了又回来继续干

练习

打印5行的三角形

解题思维:

我们把三角形切一下,然后分部完成

第一步打印1

  1. package com.xiaodi.operator.struct;
  2. public class TestDemo01 {
  3. public static void main(String[] args) {
  4. for (int i = 1; i <= 5; i++) {
  5. for (int j = 5; j >= i; j--) {
  6. System.out.print("*");
  7. }
  8. System.out.println();
  9. }
  10. }
  11. }

第二部打印2,然后把第一步打印的内容变为空格

  1. package com.xiaodi.operator.struct;
  2. public class TestDemo01 {
  3. public static void main(String[] args) {
  4. for (int i = 1; i <= 5; i++) {
  5. for (int j = 5; j >= i; j--) {
  6. System.out.print(" ");
  7. }
  8. for (int j = 1; j <= i; j++) {
  9. System.out.print("*");
  10. }
  11. System.out.println();
  12. }
  13. }
  14. }

第三步打印第三部分

  1. package com.xiaodi.operator.struct;
  2. public class TestDemo01 {
  3. public static void main(String[] args) {
  4. for (int i = 1; i <= 5; i++) {
  5. for (int j = 5; j >= i; j--) {
  6. System.out.print(" ");
  7. }
  8. for (int j = 1; j <= i; j++) {
  9. System.out.print("*");
  10. }
  11. for (int j = 1; j < i; j++) {
  12. System.out.print("*");
  13. }
  14. System.out.println();
  15. }
  16. }
  17. }

如果不理解使用IDEA中的Debug

​ 在你不理解的行开始打上断点,就是在行号后面点一下,然后点击小虫子图标,然后程序运行到断点会停住,然后通过↓这个符号一步一步的去运行下去,去一步一步理解!点击console能看见当前输出的结果

这个提主要还是学思维哈,一定要去认真的理解一下,Debug也要学起来

五、Java控制流程的更多相关文章

  1. Java 控制流程 之 循环语句

    循环:循环语句可以在满足循环条件的情况下,反复执行某一段代码,这段被重复执行的代码被称为循环体语句,当反复 执行这个循环体时,需要在合适的时候把循环判断条件修改为false,从而结束循环,否则循环将一 ...

  2. java控制流程(一)

    一.scanner: scanner可以获取用户的输入的信息 scanner的初始化: //导入的包 import java.util.Scanner; public class Test { pub ...

  3. JAVA控制流程

    Java代码有三种执行结构流程,顺序结构.分支结构.循环结构 顺序结构 顺序结构是最简单的代码执行结构,从代码开始逐步执行每一句代码到结束 public class C { public static ...

  4. java控制流程(二)

    一.循环结构 有一天你的女朋友让你写一百遍我爱你,你是要一行一行的手写出来,还是利用编程的循环结构写出来? while 语法: 表达式返回的为boolean值 while(表达式){ 需要循环的语句 ...

  5. Java入门(五):控制流程

    在Java中,使用条件语句和循环结构确定控制流程,在本文中,主要包括块作用域.条件语句.循环结构.中断循环这四部分. 一.块作用域 块,也叫复合语句,是指由一对大括号括起来的若干条Java语句.块决定 ...

  6. 【JAVA零基础入门系列】Day8 Java的控制流程

    什么是控制流程?简单来说就是控制程序运行逻辑的,因为程序一般而言不会直接一步运行到底,而是需要加上一些判断,一些循环等等.举个栗子,就好比你准备出门买个苹果,把这个过程当成程序的话,可能需要先判断一下 ...

  7. java基础-控制流程语句

    一 前言 周末睡觉好舒服,都不想动了,就想睡睡,晒晒太阳,作者劳碌命还是过来写文章了.基础系列文章已经已经出到控制流程,感觉也挺快的,我很自信全网没都多少系列文章能有我这基础系列写的这么好,易于初学者 ...

  8. Java的流程控制和C++的异同

    Java的流程控制和C++基本相似 现将不同的地方总结一下,以便快速掌握. Java的特殊流程控制的特殊部分: 1.顺序结构  -- 没有区别 2.分之结构  -- 没有区别 3.循环结构 1> ...

  9. Java基础语法<四> 控制流程

    笔记整理 来源于<Java核心技术卷 I > <Java编程思想>   if while do while for   switch case case标签可以是: 类型为ch ...

随机推荐

  1. Android 关于Intent的一些简略总结

    感谢大佬:https://www.jianshu.com/p/19147a69e970 Intent 常用构造方法: | 方法 | 描述 | |Intent() | 构造一个空 Intent | | ...

  2. 入门-Kubernetes概述 (一)

    1 Kubernetes是什么 Kubernetes是Google在2014年开源的一个容器集群管理系统,Kubernetes简称K8S. K8S用于容器化应用程序的部署,扩展和管理. K8S提供了容 ...

  3. linux 设置connect 超时

    转载请注明来源:https://www.cnblogs.com/hookjc/ 将一个socket 设置成阻塞模式和非阻塞模式,使用fcntl方法,即: 设置成非阻塞模式: 先用fcntl的F_GET ...

  4. Java基础复习(五)

    1. 接口是否可继承接口? 抽象类是否可实现(implements)接口? 抽象类是否可继承具体类(concrete class)? 抽象类中是否可以有静态的main方法? 接口可以继承接口.抽象类可 ...

  5. Redis高可用(持久化、主从复制、哨兵、集群)

    Redis高可用(持久化.主从复制.哨兵.集群) 目录 Redis高可用(持久化.主从复制.哨兵.集群) 一.Redis高可用 1. Redis高可用概述 2. Redis高可用策略 二.Redis持 ...

  6. 总结Tomcat优化方法

    一.内存空间优化 配置文件目录:/usr/local/tomcat/bin/catalina.sh JAVA_OPTS="-server -Xms4g -Xmx4g -XX:NewSize= ...

  7. Aselenium前言

    https://seleniumhq.github.io/docs/index.html https://www.seleniumhq.org/ THE SELENIUM BROWSER AUTOMA ...

  8. 2018 PHP面试题

    2018 PHP面试题 题目来自<PHP程序员面试笔试宝典>,里面涵盖了近三年了各大型企业常考的PHP面试题,针对面试题提取出来各种面试知识也涵盖在了本书. 1.PHP常考基础 1.PHP ...

  9. KC705E增强版基于FMC接口的 Kintex-7 XC7K325T PCIeX8 接口卡

    一.板卡概述 本板卡基于Xilinx公司的FPGAXC7K325T-2FFG900 芯片,pin_to_pin兼容FPGAXC7K410T-2FFG900 ,支持PCIeX8.64bit DDR3容量 ...

  10. Solution -「POI 2010」「洛谷 P3511」MOS-Bridges

    \(\mathcal{Description}\)   Link.(洛谷上这翻译真的一言难尽呐.   给定一个 \(n\) 个点 \(m\) 条边的无向图,一条边 \((u,v,a,b)\) 表示从 ...