背景:现1+2+…+100,则需要做99次加法,这类问题使用循环语句解决,可以使问题变得简单。即循环语句用于实现语句块的重复执行,如果不使用循环,则可以使用递归函数(在这章中不会讲到)等待后续更新。
while的结构:
while(条件表达式 ) {
代码体 //循环内容
}
while代码例子
public class Circulate {
public static void main(String[] args) {
// TODO 自动生成的方法存根
int n = 0; // 初始化变量
int sum = 0;
while(n < 0){
n++; // 于 n = n + 1 一样
sum += n; // 与sum = sum + n 一样
};
System.out.println(n);
}
}
n的结果是:0
执行流程:
while语句在执行时,先对条件表达式进行求值判断,如果值为true,则执行代码体,代码体执行完毕以后,继续对表达式进行判断,如果为true,则继续执行循环体,以此类推,直到表达式的值为false,则终止循环。
while循环具体流程如下图
首先对sum和n初始化,然后判断n是否比0小,如果比0小,执行代码体,循环继续,否则,循环结束,输出n的值。
do···while的结构:
do { 代码体//循环内容 }while(条件表达式);
do···while代码例子
public class Circulate {
public static void main(String[] args) {
// TODO 自动生成的方法存根
int n = 1;
int sum = 0;
do{
n++;
sum += n;
}while(n < 0);
System.out.println(n);
}
}
n的结果为:1
执行流程:
do...while语句在执行时,会先执行代码体; 代码体执行完毕以后,再对while后的条件表达式进行判断; 如果结果为true,则继续执行循环体,执行完毕继续判断,以此类推,直到条件表达式的结果为false,则终止循环。
do···while循环具体流程如下图
首先对sum和n初始化,先执行代码体,然后判断n是否比0小,如果比0小,循环继续,否则,循环结束,输出n的值。
总结:while循环是先判断,后执,就像我们平时去吃饭一样,先想想口袋里有没有钱,才去吃饭。而do···while循环是先执行后判断,就像不聪明的狗一样,它会先吃饭(不会等待主人下命令之后才吃),然后在判断主人是否下达了命令(主人下次会不会不会给我吃了)