Java的流程控制结构,细节详解
位运算符
&与 |或 ^异或 <<左移 >>右移 >>>无符号右移 ~取反
注意:位运算是针对整数运算的
int i = 6,j = 10;
方式一:利用第三方变量
int k = i;
i = j;
j = k;
方式二:利用加减法
i = i + j;
j = i - j;--->j = i + j - j;-> j = i;
i = i - j;--->i = i + j - i;-> i = j;
方式三:异或运算
i = i ^ j;
j = i ^ j;---> j = i ^ j ^ j;-> j = i;
i = i ^ j;---> i = i ^ j ^ i;-> i = j;
i^=j;j^=i;i^=j;
为什么第三种方式的效率更高却是第一种方式用的更广?
第一种方式的可阅读性更高;第三种方式只能用于运算整数,第二种方式可以用于运算数值型但是不能用于交换其他类型的值例如字符串类型,而第一种方式可以交换任意一种类型的值

流程控制
顺序结构
从上倒下、从左到右一次运行
分支结构
判断结构
if(逻辑值){
代码块;
}

如果代码块只有一句,{}可以省略不写
if(逻辑值){
Code1;
} else {
Code2;
}

练习:获取较大的数
if(逻辑值1){
Code1;
} else if(逻辑值2) {
Code2;
} else {
Code3;
}
练习:输入月份,输出季节---3-5---Spring,6-8-Summer,9-11-Autumn,12-2-Winter
选择结构
switch(表达式){
case 情况1 : Code1;break;
case 情况2 : Code2;break;
……
default:Code;break;
}
注意:
1.表达式的结果是byte/short/int/char
2.从JDK1.7开始,允许匹配字符串
3.从JDK1.5开始,允许匹配枚举常量
4.当选项后边都有break的时候,选项之间的顺序没有影响;如果有一个或者以上选项之后没有break,从匹配到该选项的地方开始执行,知道遇到break或者{}结束
int i = 0;
switch(i){
case 0: int j = 0;
case 1: j+=1;
case 2: j+= 2;
case 3:j+=3;
default:j+=4;
}
System.out.printlnt(j);---报错
练习:从控制台输入两个数字以及运算符号(+、-、*、/),将两个数字按照指定的运算进行并输出结果
循环结构
while(逻辑值){
Code;
}

循环的要素:定义循环变量、控制判断条件、改变循环变量
例子:
1.求1到任意一个数的和
2. 输入任意一个整数,输出这个整数的位数
练习:
- 输入一个整数,求各位数字之和
Scanner scanner=new Scanner(System.in);
String string=scanner.nextLine();
int sum=;
for (int i = ; i < string.length(); i++) {
sum+=Integer.valueOf(String.valueOf(string.charAt(i)));
}
System.out.println(sum);
- 求300以内7的倍数
for (int i = 0; i < 300; i++) {
if (i%7==0) {
System.out.println(i);
}
}
- 输入一个整数,转化成二进制显示
Scanner scanner=new Scanner(System.in); int a=scanner.nextInt(); String nbInteger= Integer.toBinaryString(a); System.out.println(nbInteger);
如果while循环的代码块只有一句,{}可以省略
do{
Code;
} while(逻辑值);

do-while循环的代码块至少执行一次
for(定义循环变量; 控制判断条件; 改变循环变量){
代码块;
}

练习:求500以内6的倍数的和
for循环的循环变量在循环结束之后不可使用,while循环可以
当循环的次数固定或者步长固定建议使用for循环
当循环次数不定或者变化不规律的时候建议使用while
//希望用户输入一个偶数
Scanner s = new Scanner(System.in);
int even = s.nextInt();
while(even % 2 != 0){
even = s.nextInt();
}
for(;even % 2 != 0; ){
even = s.nextInt();
}
练习:打印九九乘法表
for (int i = ; i <=; i++) {
for (int j = ; j <= i; j++) {
System.out.print(j+"*"+i+"="+i*j+"\t");
}
System.out.println("");
}
1*1=1
1*2=2 2*2=4
1*3=3 2*3=6 3*3=9
Java的流程控制结构,细节详解的更多相关文章
- java 关键字final static native详解
java 关键字native static final详解 一.final 根据程序上下文环境,Java关键字final有"这是无法改变的"或者"终态的"含义, ...
- Java网络编程和NIO详解9:基于NIO的网络编程框架Netty
Java网络编程和NIO详解9:基于NIO的网络编程框架Netty 转自https://sylvanassun.github.io/2017/11/30/2017-11-30-netty_introd ...
- Java网络编程和NIO详解7:浅谈 Linux 中NIO Selector 的实现原理
Java网络编程和NIO详解7:浅谈 Linux 中NIO Selector 的实现原理 转自:https://www.jianshu.com/p/2b71ea919d49 本系列文章首发于我的个人博 ...
- Java网络编程和NIO详解5:Java 非阻塞 IO 和异步 IO
Java网络编程和NIO详解5:Java 非阻塞 IO 和异步 IO Java 非阻塞 IO 和异步 IO 转自https://www.javadoop.com/post/nio-and-aio 本系 ...
- Java网络编程和NIO详解3:IO模型与Java网络编程模型
Java网络编程和NIO详解3:IO模型与Java网络编程模型 基本概念说明 用户空间与内核空间 现在操作系统都是采用虚拟存储器,那么对32位操作系统而言,它的寻址空间(虚拟存储空间)为4G(2的32 ...
- webRTC中语音降噪模块ANS细节详解(二)
上篇(webRTC中语音降噪模块ANS细节详解(一))讲了维纳滤波的基本原理.本篇先给出webRTC中ANS的基本处理过程,然后讲其中两步(即时域转频域和频域转时域)中的一些处理细节. ANS的基本处 ...
- webRTC中语音降噪模块ANS细节详解(三)
上篇(webRTC中语音降噪模块ANS细节详解(二))讲了ANS的处理流程和语音在时域和频域的相互转换.本篇开始讲语音降噪的核心部分,首先讲噪声的初始估计以及基于估计出来的噪声算先验信噪比和后验信噪比 ...
- java中的io系统详解 - ilibaba的专栏 - 博客频道 - CSDN.NET
java中的io系统详解 - ilibaba的专栏 - 博客频道 - CSDN.NET 亲,“社区之星”已经一周岁了! 社区福利快来领取免费参加MDCC大会机会哦 Tag功能介绍—我们 ...
- Java开发利器Myeclipse全面详解
Java开发利器Myeclipse全面详解: Ctrl+1:修改代码错误 Alt+Shift+S:Source命令 Ctrl+7:单行注释 Ctrl+Shift+/ :多行注释 Ctrl+I :缩进( ...
- Java中的main()方法详解
在Java中,main()方法是Java应用程序的入口方法,也就是说,程序在运行的时候,第一个执行的方法就是main()方法,这个方法和其他的方法有很大的不同,比如方法的名字必须是main,方法必须是 ...
随机推荐
- 532. K-diff Pairs in an Array
Given an array of integers and an integer k, you need to find the number of unique k-diff pairs in t ...
- 数据库(概念、语法、DBMS、SQL语言:创建数据库、表格,添加、修改、删除数据记录)
关系型数据库:以表作为实体,以主键和外键关系作为联系的一种数据结构. 主键:在关系型数据库中,用一个唯一的标识符来标志每一行,这个标识符就是主键.主键有两个特点:非空和不能重复. 外键:在关系型数据库 ...
- Spring AOP高级——源码实现(2)Spring AOP中通知器(Advisor)与切面(Aspect)
本文例子完整源码地址:https://github.com/yu-linfeng/BlogRepositories/tree/master/repositories/Spring%20AOP%E9%A ...
- 《天书夜读:从汇编语言到windows内核编程》十 线程与事件
1)驱动中使用到的线程是系统线程,在system进程中.创建线程API函数:PsCreateSystemThread:结束线程(线程内自行调用)API函数:PsTerminateSystemThrea ...
- [转载] ZooKeeper实现分布式队列Queue
转载自http://blog.fens.me/zookeeper-queue/ 让Hadoop跑在云端系列文章,介绍了如何整合虚拟化和Hadoop,让Hadoop集群跑在VPS虚拟主机上,通过云向用户 ...
- AIO5系统中关于赠品处理的方法
最近频繁有人问我,关于赠品在AIO5系统中如何处理.首先AIO5系统支持赠品处理关于赠品,在AIO5系统中走的是[其他出库单]路径:仓库--仓库作业--其他出库单--新增(如下图) 通常赠品对应的业务 ...
- 一、Hadoop学习笔记————概述
hadoop使用java编写,版本较为混乱,初学者可从1.2.1开始学习
- JAVA基础2——类初始化相关执行顺序
类初始化相关执行顺序 几个概念说明 代码块的含义与作用 static静态代码块: 一般用于初始化类中的静态变量.比如:给静态的数组或者list变量赋初值.使用static静态代码块进行初始化与直接在定 ...
- webpack之前端性能优化(史上最全,不断更新中。。。)
最近在用webpack优化首屏加载性能,通过几种插件之后我们上线前后的速度快了一倍,在此就简单的分享下吧,先上个优化前后首屏渲染的对比图. 可以看到总下载时间从3800ms缩短到1600ms. 我们在 ...
- 晓莲说-何不原创:java 实现二维数组冒泡排序
新手从业路-为自己回顾知识的同时,也希望和大家分享经验: 话不多说,上代码 public class 冒泡排序 { /** * @param admin * @2017.12.4 ...