Java学习day05

【switch】
属于选择结构,分支语句

语法结构:

/*
switch(int或string类型字面值或变量)
{
case int或string类型字面值或变量 :
java语句;
break; //若此处没有break则,继续执行下面的case语句,直到遇见break,switch执行结束
case int或string类型字面值或变量 :
java语句;
break;
...
default :
java语句;
...
}
**byte,short,char型的变量也可以放在switch、case之后,因为可以进行自动类型转换
JDK6,switch和case后 只能跟int类型
JDK7及之后,可以跟string类型,比如 case "星期一" :...;break; //注意加""
此外,case语句可以合并,比如:
int i = 1;
switch(i)
case 1 : case 2 : case 3 : case 10: //适用于多种情况,同样处理
System.out.println("Test code");

实现
+
-
*
/
%
思路:
1.键盘输入
2.用switch判断
3.输入三次
第一个数字
运算符
第二个数字

显示场景:
欢迎市容简单计算器系统:
请输入第一个数字:10
请输入运算符:
请输入第二个数字:20
运算结果:10 + 20 = 30

*/

public class SwitchTest01
{
public static void main(String[] args)
{
java.util.Scanner s = new java.util.Scanner(System.in);
System.out.print("欢迎使用简单计算器系统!");
System.out.print("请输入第一个数字:");
int num1 = s.nextInt(); //注意格式Int
System.out.print("请输入运算符:");
String str = s.next();
System.out.print("请输入第二个数字:");
int num2 = s.nextInt();
int result = 0;
switch (str)
{
case "+": result = num1 + num2 ; break; //不要写成case '+',注意String类型,而不是char
case "-": result = num1 - num2 ; break;
case "*": result = num1 * num2 ; break;
case "/": result = num1 / num2 ; break;
case "%": result = num1 % num2 ; break;
default: System.out.println("不合法字符") ;

}
System.out.println(num1 + str + num2 + "=" + result);
}
}

【循环结构】

- for

语法结构:

for ( 初始化表达式 ; 布尔表达式 ; 更新表达式 )

{

  

}

其中,()内的三个表达式都不是必须的缺少任意一个或者多个都没问题,但 ; 不能少

初始化表达式先执行,且执行一次

判断布尔表达式真或者假

为真则执行循环体,执行完后执行更新表达式,再次执行循环体

直到布尔表达式为假,则结束循环。如果一开始为假,则不执行循环体。

死循环

for(;;)

{

  System.out.println("死循环");

}  //仅一行语句,大括号可以不加

【Crtl + C 结束运行】

for循环中定义的 i 其作用域仅限于所在循环体,无法在循环体外输出

for(int i = 0 ; ... ; ...)

{...}

【可以先定义在赋值】

int i ; i=1;

语句嵌套时,控制变量不要定义同一个字母

*******************************************************

/*使用for循环输出九九乘法表
* 1*1=1
* 2*1=2 2*2=4
* 3*1=3 3*2=6 3*3=9
* 4*1=4 4*2=8 4*3=12 4*4=16
* 5*1=5 5*2=10 5*3=15 5*4=20 5*5=25
* 6*1=6 6*2=12 6*3=18 6*4=24 6*5=30 6*6=36
* 7*1=7 7*2=14 7*3=21 7*4=28 7*5=35 7*6=42 7*7=49
* 8*1=8 8*2=16 8*3=24 8*4=32 8*5=40 8*6=48 8*7=56 8*8=64
* 9*1=9 9*2=18 9*3=27 9*4=36 9*5=45 9*6=54 9*7=63 9*8=72 9*9=81
*/

public class ForTest01
{
public static void main(String[] args)
{
int i = 0;
for (i = 1 ;i <= 9 ;i++) //行数
{
for (int j = 1 ;j <= i ;j++)
{
System.out.print(i + "*" + j + "=" + i * j);
System.out.print(" ");
}
System.out.print("\n");
}
}
}

**************************************************

【 while】

结构:

while(布尔表达式)  //先判断表达式,true则执行循环体,false退出循环

{

  循环体;  //循环执行,执行完判断布尔表达式

}

死循环后的语句无法被访问,编译也许会报错

- do..while()

结构:

do{

 循环体; 

}while(布尔表达式);

先执行循环体,再判断表达式,循环体至少执行一次

* 控制循环的语句

【break】

不仅可以用于switch语句中的case

也可以用于终止循环语句,比如for循环

如遇到循环嵌套,则break终止离其最近的循环。

除非:

【continue】

------部分摘自B站动力节点教育集团

Java学习day05的更多相关文章

  1. Java 学习 day05

    01-面向对象(概述) 面向对象 -- 冰箱.打开:冰箱.存储:冰箱.关闭: 02-面向对象(举例) 使用和指挥 -- 对象,不需要关注过程,只关注结果: 一切皆对象,万物皆对象  -- 自<T ...

  2. 0037 Java学习笔记-多线程-同步代码块、同步方法、同步锁

    什么是同步 在上一篇0036 Java学习笔记-多线程-创建线程的三种方式示例代码中,实现Runnable创建多条线程,输出中的结果中会有错误,比如一张票卖了两次,有的票没卖的情况,因为线程对象被多条 ...

  3. 0035 Java学习笔记-注解

    什么是注解 注解可以看作类的第6大要素(成员变量.构造器.方法.代码块.内部类) 注解有点像修饰符,可以修饰一些程序要素:类.接口.变量.方法.局部变量等等 注解要和对应的配套工具(APT:Annot ...

  4. 分享篇——我的Java学习路线

    虽然之前我是开发出身,但是我学习的语言是Objective-c,这个语言使用起来范围比较窄,对于自动化学习来说也是无用武之地,所以我自己学习了Java,对于一个有开发经验的人来说学习一门新语言相对来说 ...

  5. Java学习笔记(04)

    Java学习笔记(04) 如有不对或不足的地方,请给出建议,谢谢! 一.对象 面向对象的核心:找合适的对象做合适的事情 面向对象的编程思想:尽可能的用计算机语言来描述现实生活中的事物 面向对象:侧重于 ...

  6. Java学习心得之 HttpClient的GET和POST请求

    作者:枫雪庭 出处:http://www.cnblogs.com/FengXueTing-px/ 欢迎转载 Java学习心得之 HttpClient的GET和POST请求 1. 前言2. GET请求3 ...

  7. 0032 Java学习笔记-类加载机制-初步

    JVM虚拟机 Java虚拟机有自己完善的硬件架构(处理器.堆栈.寄存器等)和指令系统 Java虚拟机是一种能运行Java bytecode的虚拟机 JVM并非专属于Java语言,只要生成的编译文件能匹 ...

  8. 0030 Java学习笔记-面向对象-垃圾回收、(强、软、弱、虚)引用

    垃圾回收特点 垃圾:程序运行过程中,会为对象.数组等分配内存,运行过程中或结束后,这些对象可能就没用了,没有变量再指向它们,这时候,它们就成了垃圾,等着垃圾回收程序的回收再利用 Java的垃圾回收机制 ...

  9. 0028 Java学习笔记-面向对象-Lambda表达式

    匿名内部类与Lambda表达式示例 下面代码来源于:0027 Java学习笔记-面向对象-(非静态.静态.局部.匿名)内部类 package testpack; public class Test1{ ...

随机推荐

  1. drf中View和router的详解

    Rest Framework 视图和路由 因为涉及到视图层面了,而且下面的例子会反复用到request.data,所以我决定带大家稍微看下源码,感兴趣的可以自己深入了解 无论是View还是APIVie ...

  2. Angular 之我见

    很久没有写过技术软文了,虽然 Angular 发布已有四年,得到了越来越多人的关注,但是仍然有很多人不分青红皂白的进行诋毁.我打算结合自己的经历从客观的角度说聊一聊我眼中的 Angular. 本人刚做 ...

  3. k8s-1.15.0集群部署+dashboard

    环境:外网环境硬件master-centos7.4  2核4G node1-centos7.4     2核4Gnode2-centos7.4     2核4G软件:三台服务器 :docker-19. ...

  4. Codeforces Round #580 (Div. 2)-D. Shortest Cycle(思维建图+dfs找最小环)

    You are given nn integer numbers a1,a2,…,ana1,a2,…,an. Consider graph on nn nodes, in which nodes ii ...

  5. Codeforces Round #560 (Div. 3)A-E

    A. Remainder output standard output You are given a huge decimal number consisting of nn digits. It ...

  6. leetcode-双指针遍历

    编写一个函数,其作用是将输入的字符串反转过来.输入字符串以字符数组 char[] 的形式给出.不要给另外的数组分配额外的空间,你必须原地修改输入数组.使用 O(1) 的额外空间解决这一问题.你可以假设 ...

  7. FastJSON解析JSON的时候保证深堆的顺序

    普通的JSONObject.parseObject(),解析的时候,底层采用HashMap解析所以是无序的, JSONObject params = JSONObject.parseObject(ex ...

  8. [Java数据结构]HashSet,LinkedHashSet,TreeeSet

    Java中Set表示一个不包括重复元素的集合,它有HashSet,LinkedHashSet,TreeeSet三种常用实现. HashSet是Set的最常用实现,它常被用来清除重复元素. 例程: Se ...

  9. leetcode刷题-90子集 II

    题目 给定一个可能包含重复元素的整数数组 nums,返回该数组所有可能的子集(幂集). 说明:解集不能包含重复的子集. 示例: 输入: [1,2,2]输出:[ [2], [1], [1,2,2], [ ...

  10. House of Orange

    题目附件:https://github.com/ctfs/write-ups-2016/tree/master/hitcon-ctf-2016/pwn/house-of-orange-500 查看程序 ...