顺序结构

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

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

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

选择结构

  • if

 if(布尔表达式){
     //布尔表达式为true将执行的语句
 }
 if(布尔表达式){
     //布尔表达式为true将执行的语句
 }else{
    //布尔表达式为true将执行的语句
 }
 if(布尔表达式1){
     //布尔表达式1为true将执行的语句
 }else if(布尔表达式2){
     //布尔表达式2为true将执行的语句
 }else if(布尔表达式3){
     //布尔表达式3为true将执行的语句
 }else{
     //以上布尔表达式都不为true被执行的代码
 }
 if(布尔表达式1){
     //布尔表达式1为true将执行的语句
     if(布尔表达式2){
     //布尔表达式2为true将执行的语句
 }
 }
  • switch

    • switch语句中的变量类型可以是:byte、short、int或者char

    • 从java SE7开始支持String类型

    • case标签必须为字符串常量或字面量

 switch(expression){
     case value:
         //语句
         break;//可选
     case value:
         //语句
         break;//可选
         。。。
     default://可选
         //语句
 }

循环结构

while:

  • 不满足条件不会进入循环

 while(布尔表达式){
     //循环内容
 }

do...while:

  • 循环最少执行1次

 do{
     //执行代码
 }while(布尔值表达式)

while和do while的区别:

  • while先判断后执行。do while是先执行后判断!

  • do while保证循环体最少被执行一次

for循环

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

for循环执行次数是在执行以前就确定的。

 for(初始化;布尔表达式;更新){
     //代码语句
 }
 九九乘法表
 public class ForDemo04 {
     public static void main(String[] args) {
         for (int j=1;j<=9;j++){
             for (int i=1;i<=j;i++){
                 System.out.print(i+"*"+j+"="+(i*j)+"\t");
            }
             System.out.println();
        }
    }
 }

增强for循环

  • java5引入了一种主要用于数组或集合的增强型for循环。

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

break

在任何循环语句主体部分,均可用break控制循环流程。用于强行退出循环,不执行循环中剩下的语句

continue

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

随机推荐

  1. [转]Vue之引用第三方JS插件

    1.绝对路径引入,全局使用. 在index.html文件中使用script标签引入插件. 该种方式就是上面演示ckplayer插件使用的方式. 备注: 这种方式的引用,会在开启ESLint时,报错,可 ...

  2. List接口的实现类

    (一): ArrayList  构造方法 特有的方法: LinkedList 特点: 可以调用Collections类的静态方法 synchronizedCollection转换成线程安全的

  3. 聊聊同步、异步、阻塞、非阻塞以及IO模型

    前言 在使用Netty改造手写RPC框架的时候,需要给大家介绍一些相关的知识,这样很多东西大家就可以看明白了,手写RPC是一个支线任务,后续重点仍然是Kubernetes相关内容. 阻塞与非阻塞 同步 ...

  4. 局域网内部怎么安全接入U盘?

    准备工具: 内部专用U盘一个: 能连接外网的电脑(暂称"安全机")一个. 第一.安全机上安装360杀毒.360安全卫士或其它安全软件.并经常更新病毒库.木马库. 第二.外来U盘先通 ...

  5. 《剑指offer》面试题53 - II. 0~n-1中缺失的数字

    问题描述 一个长度为n-1的递增排序数组中的所有数字都是唯一的,并且每个数字都在范围0-n-1之内.在范围0-n-1内的n个数字中有且只有一个数字不在该数组中,请找出这个数字. 示例 1: 输入: [ ...

  6. leetcode 509. 斐波那契数

    问题描述 斐波那契数,通常用 F(n) 表示,形成的序列称为斐波那契数列.该数列由 0 和 1 开始,后面的每一项数字都是前面两项数字的和.也就是: F(0) = 0,   F(1) = 1 F(N) ...

  7. 【pwn】学pwn日记——栈学习(持续更新)

    [pwn]学pwn日记--栈学习(持续更新) 前言 从8.2开始系统性学习pwn,在此之前,学习了部分汇编指令以及32位c语言程序的堆栈图及函数调用. 学习视频链接:XMCVE 2020 CTF Pw ...

  8. 【刷题-LeetCode】239. Sliding Window Maximum

    Sliding Window Maximum Given an array nums, there is a sliding window of size k which is moving from ...

  9. android+opencv+opencl: cv::dft()的opencl版本的性能分析

    在小米mix 2s + 高通骁龙 845 + Adreno 630 上测试了opencl版本的cv::dft(). 测试数据 先看表格里面的描述: 名称 函数名 最大时间(ms) 平均时间(ms) 说 ...

  10. golang中闭包讲解

    1. 非闭包时的结果 package main import "fmt" func main() { var funcSlice []func() for i := 0; i &l ...