1 条件语句

条件语句,即类似 if...else... 的语句,一个if语句包含了一个布尔表达式,以及一个或多个语句。

if语句语法

if(布尔表达式) {
// 布尔表达式为true时执行的语句块
}

if...else语句语法

if(布尔表达式) {
// 布尔表达式为true时执行的语句块
} else {
// 布尔表达式为false时执行的语句块
}

if...else if...else语句语法

if(布尔表达式1) {
// 布尔表达式1为true时执行的语句块
} else if (布尔表达式2) {
// 布尔表达式1为false,但是布尔表达式2为true时执行的语句块
} else {
// 布尔表达式1和布尔表达式2均为false时执行的语句块
}

注意:若同一个if语句中有多个else if语句,则类似的会有多个布尔表达式来判断,从上到下地依次判断if中的布尔表达式,只要判断到其中有一个布尔表达式为true则进入相应的代码块,而不会在往下判断其他的else if和else语句。

实例演示:

public class MyFirst {

    public static void main(String[] args) {
Integer a1 = 2;
Integer a2 = 3;
Integer a3 = 2; if (a1 == a2) {
System.out.println("进入第一个if结构");
} else if (a1 == a3) {
System.out.println("进入第二个if结构");
} else {
System.out.println("进入最后的if结构");
}
} }

运行结果是,进入了第二个if结构块执行代码,输出:进入第二个if结构

2 循环结构

顺序结构的程序语句只能被执行一次,但是如果你想要同样的操作执行多次的话,则需要循环结构的语句来实现了。Java中主要有三种循环结构分别是,while循环、do...while循环和for循环。

 while循环

先判断布尔表达式,再执行循环内容。

// 若布尔表达式为true,则进入循环块执行循环的内容,而后每一次执行循环内容之前都会判断布尔表达式是否为true,再来决定是否执行循环内容
while(布尔表达式) {
// 循环的内容
}

示例:

public class MyFirst {

    public static void main(String[] args) {
Integer start = 1;
Integer end = 5; while (start <= end) {
System.out.println("当前的start值:" + start);
start++;
} } }

循环了5次,输出的值依次如下所示:

当前的start值:1
当前的start值:2
当前的start值:3
当前的start值:4
当前的start值:5

do...while循环

与while循环类似,唯一的区别是,do...while无论如何都会先执行一次循环内容。

// 先执行循环内容,再判断布尔表达式是否为true,以此来决定是否再次执行循环内容
do {
// 循环的内容
} while(布尔表达式);

示例:

public class MyFirst {

    public static void main(String[] args) {
Integer start = 1;
Integer end = 5; do {
System.out.println("当前的start值:" + start);
start++;
} while (start > end); } }

虽然 start > end 判断条件不符,但是仍然会先执行一次循环内容,输出结果:

当前的start值:1

for循环

for循环执行的次数是在一开始的时候就已经决定好的。

// 先初始化;再判断布尔表达式是否为true,为true则执行循环内容;最后更新初始化的值,进入下一次循环,判断布尔表达式是否为true。。。
for(初始化; 布尔表达式; 更新) {
// 循环的内容
}

示例:

public class MyFirst {

    public static void main(String[] args) {
for (int i=1; i<=5; i++) {
System.out.println("当前循环次数:" + i);
}
} }

循环了5次,输出结果为:

当前循环次数:1
当前循环次数:2
当前循环次数:3
当前循环次数:4
当前循环次数:5

另外这里扩展一下,Java5引入的主要应用于数组的增强型for循环,示例如下:

public class MyFirst {

    public static void main(String[] args) {
int[] arr = {10, 20, 30, 40, 50};
for (int i : arr) {
System.out.println("当前循环所在的数组值:" + i);
}
} }

循环了5次,输出结果为:

当前循环所在的数组值:10
当前循环所在的数组值:20
当前循环所在的数组值:30
当前循环所在的数组值:40
当前循环所在的数组值:50

break

在循环体中,break是可以跳出当前循环体,继续执行循环以外的语句。

public class MyFirst {

    public static void main(String[] args) {
for (int i=1; i<=5; i++) {
// 若i大于2则会跳出循环
if (i > 2) {
break;
}
System.out.println("当前循环次数:" + i);
}
} }

由于有了break跳出循环的操作,故此处只循环了两次输出:

当前循环次数:1
当前循环次数:2

continue

在循环体中,continue是可以跳过当次循环在continue语句执行后的内容,进入下一次循环。

public class MyFirst {

    public static void main(String[] args) {
for (int i=1; i<=5; i++) {
// 若i等于2则会跳过此次循环的内容,直接进入下一次循环
if (i == 2) {
continue;
}
System.out.println("当前循环次数:" + i);
}
} }

输出如下:

当前循环次数:1
当前循环次数:3
当前循环次数:4
当前循环次数:5

return

return关键字,主要是用于方法的返回,即使是在循环体内也会直接返回,终止次方法继续向下执行。

public class MyFirst {

    public static void main(String[] args) {
for (int i=1; i<=5; i++) {
// 若i等于2则会直接终止此方法继续向下执行
if (i == 2) {
return;
}
System.out.println("当前循环次数:" + i);
} System.out.println("执行完毕!");
} }

输出如下:

当前循环次数:1

3 switch case语句

switch case语句,主要用于判断某一变量与一系列的值中哪个值相等,则进入该值所在的分支语句块。

switch(变量){
case 值1 :
//语句
break; //可选
case 值2 :
//语句
break; //可选
//你可以有任意数量的case语句
default : //可选
//语句
}
  • 变量的类型一般是int、short、byte、char或String,并且必须case后面的值必须是常量或者字面值。
  • break可以有也可以没有,若有break值则会直接跳出switch语句块,否则会在switch语句块中一直执行下去。
  • default分支一般在switch语句块的末尾,是可有可无的,不需要break。
  • switch case语句执行时,一定是先匹配switch的变量值,若匹配到其中一个case的值则会进入该case的分支,再根据该case分支中是否有break,判断是否继续匹配下一个case或者直接跳出switch语句块。
public class MyFirst {

    public static void main(String[] args) {
int a = 2;
switch (a) {
case 1 :
System.out.println("case 1");
break;
case 2 :
System.out.println("case 2");
break;
default:
System.out.println("default");
}
} }

a变量匹配到2,故直接进入case 2的分支,分支执行完后发现有break就直接跳出switch语句,输入如下:

case 2

感慨

不管是条件语句,还是循环结构,或者switch case语句,都是我们在Java中比较常见,也是必须熟悉的语句。其实不单止是Java,在其他语言中都会大同小异的用到这些语句。

基础篇-1.4Java流程语句的基础的更多相关文章

  1. Java基础(二)流程语句与数组

    Java流程语句详解:https://www.cnblogs.com/jiajia-16/p/6008200.html Java数组详解:https://www.cnblogs.com/jiajia- ...

  2. Java基础篇(03):流程控制语句,和算法应用

    本文源码:GitHub·点这里 || GitEE·点这里 一.分支语句 流程控制语句对任何一门编程语言都是非常重要的,Java中基于流程控制程序执行的不同步骤和代码块. 1.IF条件 IF条件语句会根 ...

  3. C++入门到理解阶段二基础篇(5)——C++流程结构

    1.顺序结构 程序从上到下执行 2.选择结构(判断结构) 判断结构要求程序员指定一个或多个要评估或测试的条件,以及条件为真时要执行的语句(必需的)和条件为假时要执行的语句(可选的). ​ C++ 编程 ...

  4. Spark修炼之道(基础篇)——Linux大数据开发基础:第二节:Linux文件系统、文件夹(一)

    本节主要内容 怎样获取帮助文档 Linux文件系统简单介绍 文件夹操作 訪问权限 1. 怎样获取帮助文档 在实际工作过程其中,常常会忘记命令的使用方式.比如ls命令后面能够跟哪些參数,此时能够使用ma ...

  5. Spark修炼之道(基础篇)——Linux大数据开发基础:第三节:用户和组

    本节主要内容 理解用户和组的概念 用户管理 组管理 权限分配 1. 理解用户和组的概念 在第一讲中我们提到.linux是一种多任务.多用户的操作系统,在讲ls -l命令行我们看到例如以下文件具体信息: ...

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

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

  7. SQL Server调优系列基础篇(并行运算总结)

    前言 上三篇文章我们介绍了查看查询计划的方式,以及一些常用的连接运算符.联合运算符的优化技巧. 本篇我们分析SQL Server的并行运算,作为多核计算机盛行的今天,SQL Server也会适时调整自 ...

  8. SQL Server调优系列基础篇(并行运算总结篇二)

    前言 上一篇文章我们介绍了查看查询计划的并行运行方式. 本篇我们接着分析SQL Server的并行运算. 闲言少叙,直接进入本篇的正题. 技术准备 同前几篇一样,基于SQL Server2008R2版 ...

  9. SQL Server调优系列基础篇(联合运算符总结)

    前言 上两篇文章我们介绍了查看查询计划的方式,以及一些常用的连接运算符的优化技巧,本篇我们总结联合运算符的使用方式和优化技巧. 废话少说,直接进入本篇的主题. 技术准备 基于SQL Server200 ...

随机推荐

  1. VS2010版的Speex音频处理模块(附源码+测试demo)

    开源的Speex代码内部包含了VS2003,05,08工程,但是直接编译总有一些要设置的地方,虽说也不是很复杂,但是对于不是很了解VS的同学来说还是要折腾一阵,所以我弄了一个可以直接使用的版本,当然是 ...

  2. thinkphp 组合查询

    组合查询的主体还是采用数组方式查询,只是加入了一些特殊的查询支持,包括字符串模式查询(_string).复合查询(_complex).请求字符串查询(_query),混合查询中的特殊查询每次查询只能定 ...

  3. Python-面向对象之封装与多态

    目录 组合 什么是组合 使用组合的目的 如何使用组合 封装 什么是封装 为什么要封装 如何封装 访问限制机制 什么是访问限制机制 访问限制机制的目的 如何使用访问限制 property 什么是prop ...

  4. raft学习

    http://thesecretlivesofdata.com/raft/ 选举 角色:  leader 领导者 Follower跟随者  Candidate候选者 如果跟随者在一定时间内,么有收到领 ...

  5. 菜鸟nginx源码剖析数据结构篇(三) 单向链表 ngx_list_t[转]

    菜鸟nginx源码剖析数据结构篇(三) 单向链表 ngx_list_t Author:Echo Chen(陈斌) Email:chenb19870707@gmail.com Blog:Blog.csd ...

  6. 《DSP using MATLAB》Problem 8.2

    代码: %% ------------------------------------------------------------------------ %% Output Info about ...

  7. 【机器学习】机器学习入门02 - 数据拆分与测试&算法评价与调整

    0. 前情回顾 上一周的文章中,我们通过kNN算法了解了机器学习的一些基本概念.我们自己实现了简单的kNN算法,体会了其过程.这一周,让我们继续机器学习的探索. 1. 数据集的拆分 上次的kNN算法介 ...

  8. Leetcode139. Word Break单词拆分

    给定一个非空字符串 s 和一个包含非空单词列表的字典 wordDict,判定 s 是否可以被空格拆分为一个或多个在字典中出现的单词. 说明: 拆分时可以重复使用字典中的单词. 你可以假设字典中没有重复 ...

  9. [转]C#设计模式(4)-Simple Factory Pattern

    工厂模式专门负责将大量有共同接口的类实例化.工厂模式可以动态决定将哪一个类实例化,不必事先知道每次要实例化哪一个类.工厂模式有以下几种形态: 简单工厂(Simple Factory)模式 工厂方法(F ...

  10. hdu1527

    hdu1527两堆博弈模型,威佐夫博弈 #include<iostream> #include<cstdio> #include<queue> #include&l ...