Java学习笔记3--Java流程控制语句
Javadoc文档的生成方式
- 
命令行方式(cmd)
- 
javadoc -encoding UTF-8 -charset UTF-8 类名.java
 
 - 
 - 
IDEA方式
- 
记得这段配置,否则会报错
-encoding UTF-8 -charset UTF-8 -windowtitle "文档HTML页面标签的标题" -link http://docs.Oracle.com/javase/7/docs/api - 
 
 
用户交互Scanner
- 
Scanner对象
- 
工具类,java.util.Scanner是Java5的新特征,通过Scanner类来获取用户的输入。
 - 
基本语法
- 
Scanner s = new Scanner(System.in) ;
 
 - 
 - 
通过Scanner类的next()与nextLine()方法获取输入的字符串,在读取前我们一般需要使用hasNext()与hasNextLine()判断是否还有输入的数据。
- 
next():
- 
一定要读取到有效字符后才可以结束输入
 - 
对输入有效字符之前遇到的空白,next()方法会自动将其去掉
 - 
只有输入有效字符后才将其后输入的空白作为分隔符或者结束符
 - 
next()不能得到带有空格的字符串
 
 - 
 - 
package com.JXinLove.scanner;
import java.util.Scanner;
public class Demo01 {
public static void main(String[] args) {
//创建一个扫描器对象,用于接收键盘数据
Scanner scanner = new Scanner(System.in);
System.out.println("使用next方法接收:");
//判断用户有没有输入字符串
if (scanner.hasNext()==true){
//使用next方式接收
String string=scanner.next();
System.out.println("输入的内容为:"+string);
}
//使用IO流的类如果不关闭会一直占用资源,要养成良好的习惯,将用完的资源关闭
scanner.close();
}
} - 
nextLine():
- 
以Enter为结束符,也就是说nextLine()方法返回的是输入回车之前的所有字符
 - 
可以获得空白
 
 - 
 - 
package com.JXinLove.scanner;
import java.util.Scanner;
public class Demo02 {
public static void main(String[] args) {
//创建一个扫描器对象,用于接收键盘数据
Scanner scanner = new Scanner(System.in);
System.out.println("使用nextLine方法接收:");
//判断用户有没有输入字符串
if (scanner.hasNextLine()==true){
//使用next方式接收
String string=scanner.nextLine();
System.out.println("输入的内容为:"+string);
}
//使用IO流的类如果不关闭会一直占用资源,要养成良好的习惯,将用完的资源关闭
scanner.close();
}
} 
 - 
 
 - 
 
顺序结构
- 
Java的基本结构就是顺序结构,除非有特别指明,否则就一步一步执行下去。
 - 
顺序结构是最简单的算法结构
 - 
语句与语句之间,框与框之间是按从上到下的顺序进行的,它是由若干个依次执行的处理步骤组成的,它是任何一个算法都离不开的一种基本算法结构。
 
选择结构
- 
if单选择结构
- 
语法
if(布尔表达式){
//如果布尔表达式为true将执行的语句
} 
 - 
 - 
if双选择结构
- 
语法
if(布尔表达式){
//如果布尔表达式的值为true
}else{
//如果布尔表达式的值为false
} 
 - 
 - 
if多选择结构
- 
语法
if(布尔表达式1){
//如果布尔表达式1的值为true执行代码
}else if(布尔表达式2){
//如果布尔表达式2的值为true执行代码
}else if(布尔表达式3){
//如果布尔表达式3的值为true执行代码
}else{
//如果以上布尔表达式都不为true执行代码
} 
 - 
 - 
嵌套的if结构
- 
语法
if(布尔表达式1){
//如果布尔表达式1的值为true执行代码
if(布尔表达式2){
//如果布尔表达式2的值为true执行代码
}
} 
 - 
 - 
switch多选择结构
- 
语法
switch(expression){
case value:
//语句
break;//可选
case value:
//语句
break;//可选
//可以有任意数量的case语句
default://可选
//语句
} 
 - 
 
循环结构
- 
while循环
- 
语法
while(布尔表达式){
//循环内容
} - 
布尔表达式为true,循环一直执行下去
 - 
大多数情况是会让循环停止下来,我们需要一个让表达式失效的方式来结束循环
 - 
少部分情况需要循环一直执行,比如服务器的请求响应监听等
 - 
循环条件一直为true就会造成无限循环,我们正常的业务编程中应该尽量避免死循环,会影响程序性能或者造成程序卡死奔溃
 - 
思考:计算1+2+3+...+100=?
public class WhileDemo {
public static void main(String[] args) {
int i=0;
int sum=0;
while (i<=100){
sum=sum+i;
i++;
}
System.out.println(sum);
}
} 
 - 
 - 
do...while循环
- 
对于while语句而言,如果不满足条件,则不能进入循环。但有时我们需要即使不满足条件,也至少执行一次。
 - 
do...while循环和while循环相似,不同的是,do...while循环至少会执行一次。
 - 
语法
do{
//代码语句
}while(布尔表达式) - 
while和do...while的区别:
- 
while先判断后执行。do...while是先执行后判断
 - 
do...while总是保证循环体会被至少执行一次!这是他们的主要差别
 
 - 
 
 - 
 - 
for循环
- 
for循环语句是支持迭代的一种通用结构,是最有效、最灵活的循环结构。
 - 
for循环执行的次数是在执行前就确定的。语法如下:
for(初始化;布尔表达式;更新){
//代码语句
} - 
练习
- 
计算0到100之间的奇数和偶数的和
public class ForDemo {
public static void main(String[] args) {
int oddSum = 0;
int evenSum = 0;
for (int i = 0; i <= 100; i++) {
if (i%2!=0){
oddSum+=i;
}else {
evenSum+=i;
}
}
System.out.println("奇数的和"+oddSum);
System.out.println("偶数的和"+evenSum);
}
} - 
用while或for循环输出1-1000之间能被5整除的数,并且每行输出3个
//方法一:
for (int i=1;i<1001;i++){
if (i%5==0){
System.out.print(i+"\t");
}
if (i%(5*3)==0){
System.out.println();
}
}
//方法二:
int count = 0;
for (int i = 1; i <= 1000; i++) {
if (i%5==0){
System.out.print(i+"\t");
count++;
}
if (count%3==0){
System.out.println();
}
}
//方法三:
int i = 1;
int count = 0;
while (i<1001){
if (i%5==0){
System.out.print(i+"\t");
count++;
}
i++;
if (count%3==0){
System.out.println();
}
} - 
打印九九乘法表
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循环
- 
语法:
for(声明语句:表达式){
//代码句子
} - 
声明语句:声明新的局部变量,该变量的类型必须和数组元素的类型匹配。其作用域限定在循环语句块,其值与此时数组元素的值相等。
 - 
表达式是要访问的数组名,或者是返回值为数组的方法。
 
 - 
 - 
break和continue
- 
break在任何循环语句的主体部分,均可用break控制循环的流程。break用于强行退出循环,不执行循环中剩余的语句。(break语句也在switch语句中使用)
 - 
 
 - 
 
                    
                
                
            
        
浙公网安备 33010602011771号