while和do while的用法区别

article/2025/9/15 22:31:10

前言

在上一篇文章中,壹哥给大家讲解了循环的概念,并重点给大家讲解了for循环的使用。但在Java中,除了for循环之外,还有while、do-while、foreach等循环形式。今天小千就再用一篇文章,给大家讲解while循环的使用。

本文带有丰富案例及配图,让你更好地理解和运用文中的技术概念,并可以给你带来具有足够启迪的思考......

一. while循环

1. 基本语法

while循环的基本语法如下所示:

while(循环条件){ //循环体 
}

while循环属于是一种“当型”的循环结构,当循环条件为true,循环体就会执行,不满足条件,循环体一次也不会执行。所以在while循环中,当执行到一定的程度后,循环条件要变成false,否则就会变成”死循环“。死循环会导致CPU被100%占用,用户会感觉电脑运行缓慢,所以我们要避免编写死循环代码。另外如果循环条件的逻辑写得有问题,也可能会造成意料之外的结果。

大家还要注意,在while循环中,也是可以进行嵌套其他循环的!

2. 执行顺序

根据while循环的基本语法,壹哥给大家梳理一下它的执行顺序:

1如果while循环里的条件为true,则执行循环体;

2循环体执行完毕后,会再次判断循环条件......;

3直到循环条件为false,就结束循环。

3. 代码案例

接下来我们就通过几个案例来学习while循环的使用。

3.1 案例一

需求:用while循环打印100遍“跟壹壹哥学Java”

public class Demo05 {public static void main(String[] args) {// while循环//打印100遍“跟壹壹哥学Java”int i = 0;while (i < 100) {System.out.println("跟壹壹哥学Java"+i);//注意要更改i的值,否则条件就用于为真,这就成了死循环了i++;}}}

3.2 案例二

需求:用while循环计算1-100的累加和

public class Demo05 {public static void main(String[] args) {// while循环//计算1~100的和int j = 1;int sum = 0;while(j < 101){            sum = sum + j;j++;}System.out.println(sum);}}

3.3 扩展案例

需求:计算一个数是几位数?

实现思路:如果我们要想实现这个需求,可以将该数循环除以10,并用一个数字记录一共运算了几次。

public class Demo06 {public static void main(String[] args) {// while循环// 计算一个数是几位数? 实现思路:将该数循环除以10,记录运算了几次int num = 12345;int temp = num;if (num == 0) {System.out.println(num + "是1位数");} else {// 定义一个变量,用于保存循环的次数int count = 0;while (num != 0) {// 将这个数循环除以10num = num / 10;// 每次循环次数+1count++;}System.out.println(temp + "是" + count + "位数");}}}

二. do-while循环

对while循环而言,如果不满足条件,就不能进入循环。但有时我们需要即使不满足条件,也要至少执行一次,这时就可以考虑使用do-while循环了。do…while循环和while循环功能相似,不同的是,do…while循环至少会执行一次。

1. 基本语法

do-while循环的基本语法如下:

do{ //循环体 
}while(循环条件);

do-while循环属于是一种“直到型”的循环结构。因为循环条件是在循环体的后面,所以循环体在判断循环条件之前已经执行一次了。如果循环条件的值为true,则循环体会一直执行,直到循环条件的值为false,就结束循环。

大家注意:在do-while循环中,也是可以进行嵌套其他循环的!

2. 执行顺序

根据do-while循环的基本语法,壹哥给大家梳理一下它的执行顺序:

1先执行一次循环体;

2如果while循环里的条件为true,则继续执行循环体;

3当循环体执行完毕后,会再次判断循环条件......;

4直到循环条件为false,就结束循环。

3. 代码案例

3.1 案例一

需求:用do-while循环打印100遍"跟一一哥学编程"。

public class Demo06 {public static void main(String[] args) {// do-while循环// 案例:打印100遍"跟一一哥学编程"int i = 1;do {//循环体至少会执行一次System.out.println("跟一一哥学编程"+i);//更改i变量的值i++;} while (i <= 100);}}

3.2 案例二

需求:学生根据老师的评语,决定是否继续敲代码,直到测评为ok,就结束。

public class Demo06 {public static void main(String[] args) {// do-while循环//案例:学生根据老师的评语,是否继续敲代码,直到测评结果为ok才结束。Scanner sc = new Scanner(System.in);String result;do{System.out.println("敲代码ing...你看我的代码怎么样???");System.out.println("评价:");   //获取屏幕上输入的文本内容result = sc.next();            }while(!result.equals("ok"));}}

三. while与do-while的区别

这里壹哥把while与do-while循环的区别,给大家简单总结一下:

●语法格式的区别:

●执行次序不同;

●当初始循环条件不满足时,while循环一次都不会执行;do-while循环至少会执行一次。

四. 三种循环的对比

我们现在已经把for、while、do-while循环都学完了,它们三者之间又有哪些区别呢?

2.1 从执行顺序来看

●for、while:先判断,后执行;

●do-while:先执行,后判断;

2.2 从适用场景来看

●当循环次数确定时,一般使用for循环;

●循环次数不确定时,一般使用while或do-while循环。

以上这些区别,希望大家都可以记住。


http://chatgpt.dhexx.cn/article/53wxjNGC.shtml

相关文章

循环语句—do…while循环

目录 3.do……while循环语句 3.1do……while循环语句格式 3.2三种循环的区别 3.3总结三种循环的区别 3.do……while循环语句 3.1do……while循环语句格式 基本格式&#xff1a; do { 循环体语句&#xff1b; } while&#xff08;条件判断语句&#xff09;&#xff1b; …

While语句与do...while语句

循环结构之while语句&#xff1a; while(表达式&#xff09; {语句} 注意&#xff1a;1.while循环的特点是先判断条件表达式&#xff0c;后执行循环体语句。 2.“语句”就是循环体。循环体可以是一个简单的语句&#xff0c;可以是复合语句&#xff08;用花括号括起来的若干语…

C/C++之while(do-while)详细讲解

目录 while循环有两个重要组成部分&#xff1a; while 是一个预测试循环 无限循环 do-while 循环 while循环有两个重要组成部分&#xff1a; 进行 true 值或 false 值判断的表达式&#xff1b;只要表达式为 true 就重复执行的语句或块&#xff1b; 图 1 显示了 while 循环的…

do{...}while(0)的用法

首发于微信公众号&#xff1a;【码农在新加坡】&#xff0c;欢迎关注。 个人博客网站&#xff1a;do{...}while(0)的用法 零.导引 第一次见到 do{...}while(0)是在学习libevent的时候&#xff0c;看到里面有很多类似 #define TT_URI(want) do { \char *ret evhttp_uri_…

if,while选择结构和while,dowhile,for循环的使用

什么是if和while选择结构 if 选择结构是根据句条件判断之后再做处理的一种语法结构&#xff0c; 语法如下&#xff1a; while是一种先判断再执行循环体的结构&#xff1b; 当while循环条件为真时才执行循环体&#xff0c;然后再判断循环条件&#xff0c;如果条件为真&#xf…

while及do while语句

编写程序时&#xff0c;许多问题都要用到循环控制。循环结构也是结构化程序设计的基本结构之一&#xff0c;因此熟练地掌握循环结构是程序设计最基本的要求。While循环、do while循环、for循环语句&#xff0c;3种循环语句在一般情况下可以相互转换 While 及dowhile语句 Whil…

代码执行顺序之循环执行:forwhiledowhile嵌套循环

代码执行顺序之循环执行 循环执行的分类 for循环while循环dowhile循环 for循环 语法&#xff1a; for(循环初始化表达式&#xff1b;循环条件表达式&#xff1b;循环后的操作表达式){ ​ // 循环体 } 执行步骤分析&#xff1a; 循环初始化表达式最先执行&#xff0c;并且只执…

dowhile的学习

dowhile的学习 dowhile 的概念及他与while的区别 package javaxunhuanjiegou; ​ public class DoWhile {public static void main(String[] args) {int a 0;int sum 0;do {sum sum a;a;} while (a < 100);System.out.println(sum);} } ​ 我们来跟直观的感受一下 于…

循环结构 --> do while循环

do while循环 do {循环体;} while(条件表达式);执行循环体 > 判断条件表达式是否成立> 若成立&#xff0c;则执行循环体 > 判断条件表达式是否成立> 若不成立&#xff0c;则循环结束do while循环主要用于至少执行一次循环体的场合中。package demo;/*编程实现do wh…

do while循环和whil循环(内含流程图)

C语言的三大循环语句除去for循环语句还剩下do while和while循环&#xff0c;因为这两个很相似所以这里放在一起讲解。希望读完本文能对你有所帮助。 do while循环和whil循环 一、do...while二、while 一、do…while do while的语法循环结构如下所示。 do while的逻辑循环结构…

SQL中join操作后面的on与where的区别

join关键字的作用是将多个表按一定的条件联合起来&#xff0c;从而可以实现从多个表中获取数据 在join后面可以接on条件和where条件&#xff0c;在这里我主要就是说这两者之间的差别 建立两张简单的用来测试的表并添加数据&#xff0c;如下所示&#xff0c;一张表名为id_name…

MySql 各种join的使用方法

具体详解如下 1 INNER JOIN(内连接) SELECT * FORM TABLE_A A INNER JOIN TABLE_B B ON A.KEY B.KEY 2 LEFT JOIN (左连接) SELECT * FORM TABLE_A A LEFT JOIN TABLE_B B ON A.KEY B.KEY 3 RIGHT JOIN (右连接) SELECT * FROM TABLE_A A RIGHT TABLE_B B ON A.KE…

SQL 中JOIN ON 的AND条件设置

关于在A LEFT JOIN B ON A.id B.id 后面跟AND 条件的测试。 有如下的结构数据&#xff1a; 注意此LEFT ON 跟AND 限制A表的场景&#xff1b; dat a.sql 1.43KB 有如下的表结构 使用SQL进行查询&#xff1a; &#xff08;1&#xff09;SELECT * FROM table_name a LEFT J…

简单说说SQL中Join的使用

最近工作中&#xff0c;遇到了一起由于慢SQL引起DB CPU > 90% &#xff0c;数据库hang住。。最终导致其他业务查询统统失败。 细看下来是由于几张大表Join关联查询引起的&#xff0c;故障本身很常见&#xff0c;不过让我想到有必要讲讲如何规避Join的问题。 以下的讨论都是基…

SQL-JOIN全解析

SQL-JOIN全解析 一、SQL JOIN的作用是什么&#xff1f;二、四种JOIN的区别三、如何使用各种join&#xff08;一&#xff09;准备测试数据&#xff08;二&#xff09;左连接&#xff08;三&#xff09;右连接&#xff08;四&#xff09;内连接&#xff08;五&#xff09;外连接 …

SQL中join语句详解

1.inner join(内连接) 只返回匹配的行。 select * from table_a a inner join table_b b on a.name b.name 2.left join(左外连接) 返回左表的全部数据&#xff0c;和右表中满足on条件的行&#xff0c;如果左表的行在右表中没有匹配的数据&#xff0c;那么这一行中右表对应…

SQL Server 数据库常用操作:多表联查(JOIN...ON语句的使用)

1.使用传统连接方式查询 (1). 有两张表Book(BookID,BookName,TypeID,AuthorID,…)&#xff0c;BookType(TypeID,TypeName)&#xff0c;查询每本书的书名和图书类型。 SELECT BookName, TypeName FROM Book, BookType WHERE Book.TypeID BookType.TypeID(2). 有三张表Book(Boo…

Oracle SQL中join方式总结

在ORACLE数据库中&#xff0c;表与表之间的SQL JOIN方式有多种&#xff08;不仅表与表&#xff0c;还可以表与视图、物化视图等联结&#xff09;。SQL JOIN其实是一个逻辑概念&#xff0c;像NEST LOOP JOIN、 HASH JOIN等是表连接的物理实现方式。 为了更直观的了解以上join方式…

SQL语句中的join用法

SQL中join的各种用法 1.自然连接&#xff08;natural join&#xff09; 自然连接将表中具有相同名称的列自动进行匹配&#xff0c;自然连接不必指定任何同等连接条件也不能认为指定哪些列需要被匹配&#xff0c;自然连接得到的结果表中&#xff0c;两表中名称相同的列只出现一次…

sql中join的各种用法

sql中join的用法 sql中join的含义可以理解为单词“join”&#xff0c;用来连接两张表&#xff0c;join所有连接方式可以分为&#xff1a; 内连接&#xff0c;外连接&#xff0c;右连接&#xff0c;左连接&#xff0c;自然连接 上面这张图已经很清晰的表明了各种连接方式的语法…