位运算符

&与 |或 ^异或 <<左移 >>右移 >>>无符号右移  ~取反

注意:位运算是针对整数运算的

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. 输入任意一个整数,输出这个整数的位数

练习:

  1. 输入一个整数,求各位数字之和
 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);
  1. 求300以内7的倍数

for (int i = 0; i < 300; i++) {

if (i%7==0) {

System.out.println(i);

}

}

  1. 输入一个整数,转化成二进制显示
 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的流程控制结构,细节详解的更多相关文章

  1. java 关键字final static native详解

    java 关键字native static final详解 一.final 根据程序上下文环境,Java关键字final有"这是无法改变的"或者"终态的"含义, ...

  2. Java网络编程和NIO详解9:基于NIO的网络编程框架Netty

    Java网络编程和NIO详解9:基于NIO的网络编程框架Netty 转自https://sylvanassun.github.io/2017/11/30/2017-11-30-netty_introd ...

  3. Java网络编程和NIO详解7:浅谈 Linux 中NIO Selector 的实现原理

    Java网络编程和NIO详解7:浅谈 Linux 中NIO Selector 的实现原理 转自:https://www.jianshu.com/p/2b71ea919d49 本系列文章首发于我的个人博 ...

  4. Java网络编程和NIO详解5:Java 非阻塞 IO 和异步 IO

    Java网络编程和NIO详解5:Java 非阻塞 IO 和异步 IO Java 非阻塞 IO 和异步 IO 转自https://www.javadoop.com/post/nio-and-aio 本系 ...

  5. Java网络编程和NIO详解3:IO模型与Java网络编程模型

    Java网络编程和NIO详解3:IO模型与Java网络编程模型 基本概念说明 用户空间与内核空间 现在操作系统都是采用虚拟存储器,那么对32位操作系统而言,它的寻址空间(虚拟存储空间)为4G(2的32 ...

  6. webRTC中语音降噪模块ANS细节详解(二)

    上篇(webRTC中语音降噪模块ANS细节详解(一))讲了维纳滤波的基本原理.本篇先给出webRTC中ANS的基本处理过程,然后讲其中两步(即时域转频域和频域转时域)中的一些处理细节. ANS的基本处 ...

  7. webRTC中语音降噪模块ANS细节详解(三)

    上篇(webRTC中语音降噪模块ANS细节详解(二))讲了ANS的处理流程和语音在时域和频域的相互转换.本篇开始讲语音降噪的核心部分,首先讲噪声的初始估计以及基于估计出来的噪声算先验信噪比和后验信噪比 ...

  8. java中的io系统详解 - ilibaba的专栏 - 博客频道 - CSDN.NET

    java中的io系统详解 - ilibaba的专栏 - 博客频道 - CSDN.NET 亲,“社区之星”已经一周岁了!      社区福利快来领取免费参加MDCC大会机会哦    Tag功能介绍—我们 ...

  9. Java开发利器Myeclipse全面详解

    Java开发利器Myeclipse全面详解: Ctrl+1:修改代码错误 Alt+Shift+S:Source命令 Ctrl+7:单行注释 Ctrl+Shift+/ :多行注释 Ctrl+I :缩进( ...

  10. Java中的main()方法详解

    在Java中,main()方法是Java应用程序的入口方法,也就是说,程序在运行的时候,第一个执行的方法就是main()方法,这个方法和其他的方法有很大的不同,比如方法的名字必须是main,方法必须是 ...

随机推荐

  1. 文本域、bootstrap-table显示以及MySQL三者间的换行符问题

    首先,今天在做项目的时候遇到的一个问题,如何实现文本输入换行以及在前台Bootstrap-table中显示也能够换行. 也许你马上就会想到说,用富文本编辑器,然而我们需要实现的只是文本输入以及换行功能 ...

  2. Asp.Net MVC 中的 Cookie(译)

    Asp.Net MVC 中的 Cookie(译) Cookie Cookie是请求服务器或访问Web页面时携带的一个小的文本信息. Cookie为Web应用程序中提供了一种存储特定用户信息的方法.Co ...

  3. .net core 开发短网址平台的思路

    最近有个客户要求开发一套短网址网站,小编现在都使用.net core进行网站开发了,以是厘厘思路,想想使用.net core 的中间件应该很容易实现. 1. 构建一个中间件,监测网站的响应状态,代码如 ...

  4. 登山(Climb)

    题目: Rocky山脉有n个山峰,一字排开,从西向东依次编号为1, 2, 3, --, n.每个山峰的高度都是不一样的.编号为i的山峰高度为hi.  小修从西往东登山.每到一座山峰,她就回头观望自己走 ...

  5. Tomcat:Can't load AMD 64-bit .dll on a IA 32 platform(问题记录)

    从报错看,这主要是应为64位-32位不兼容导致的.好在,在报此错的情况下,tomcat还是跑起来了. 具体来说,从网上搜索的一些资料来看,应该是jdk版本与tomcat不一致 .tomcat我的是64 ...

  6. JavaWeb 学习之 JSTL

    上一篇博文我们讲解了 MVC 小案例,案例中包含了基本的增.删.改.查,对这个案例的有兴趣的伙伴可以自己动手实践一下,去复习一下或者说是学点新的知识!如果有已经看过且实践过的伙伴相信对 JSP 页面中 ...

  7. 一个在java后台实现的对图片进行加网纹或水印的工具类

    import java.awt.AlphaComposite; import java.awt.Color; import java.awt.Font; import java.awt.Graphic ...

  8. 免费人脸识别APi

    今天对应一些免费的人脸识别的api 做了一下简单的对比,觉得百度开发出来的人脸识别接口还是最符合的我的要求,简单易用,容易上手. 据说百度的一些门禁也使用上了人脸识别的功能了,功能很强大,而且能识别出 ...

  9. 乐呵乐呵得了 golang入坑系列

    开场就有料,今天返回去看了看以前的文章,轻松指数有点下降趋势.一琢磨,这不是我的风格呀.一反思,合着是这段时间,脑子里杂七杂八的杂事有点多,事情一多,就忘了快乐.古话说得好:愁也一天,乐也一天,只要还 ...

  10. XSD详解二 - 简易元素、属性、内容限定

    一.XSD 简易元素 XML Schema 可定义 XML 文件的元素. 简易元素指那些只包含文本的元素.它不会包含任何其他的元素或属性. 1.什么是简易元素? 简易元素指那些仅包含文本的元素.它不会 ...