Java基础(二)

Java基础(二)

用户交互Scanner

java.util.Scanner是Java5的新特征,我们可以通过Scanner类来获取用户输入。

基本语法:

Scanner s = new Scanner(System.in);

通过Scanner类的next()与nextLine()方法获取输入的字符串,在读取前我们一般需要使用hasNext()与hasNextLine()判断是否还有输入的数据。

next方法:

public class demo1 {
    public static void main(String[] args) {
        //创造一个扫描器对象,用于接收键盘数据
        Scanner scanner = new Scanner(System.in);

        System.out.println("使用next方式接收:");

        //判断用户有没有输入字符串
        if (scanner.hasNext()) {
            //使用next方式接收
            String str = scanner.next();
            System.out.println("输出的内容为:"+str);
        }

        //凡是属于IO流的类如果不关闭会一直占用资源
        scanner.close();
    }
}

输出:

使用next方式接收:
hello world
输出的内容为:hello

进程已结束,退出代码为 0

nextLine方法:

public class demo1 {
    public static void main(String[] args) {
        //从键盘接收数据
        Scanner scanner = new Scanner(System.in);
        System.out.println("使用next方式接收:");
        //判断是否还有输入
        if (scanner.hasNextLine()) {
            //使用nextline方式接收
            String str = scanner.nextLine();
            System.out.println("输出的内容为:"+str);
        }
        scanner.close();
    }
}

输出:

使用nextLine方式接收:
hello world
输出的内容为:hello world

进程已结束,退出代码为 0

next():

  1. 一定要读取到有效字符后才可以结束输入。
  2. 对输入有效字符之前遇到的空白,next()方法会自动将其去掉。
  3. 只有输入有效字符后才将其后面输入的空白作为分隔符或结束符。
  4. next()不能得到带有空格的字符串。

nextLine():

  1. 以Enter为结束符
  2. 可以获得空白

顺序结构

  • 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:
        //语句
};

Switch case语句判断一个变量与一系列中某个值是否相等,每个值称为一个分支。

循环结构

while循环

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

只要布尔表达式为true,循环就会一直执行下去。
我们大多数情况是会让循环停止下来的,我们需要一个让表达式失效的方式来结束循环。
少部分情况需要循环一直执行,比如服务器的请求响应监听等。
循环条件一直为true就会造成无限循环[死循环],我们正常的业务编程中应该尽量避免死循环。会影响程序性能或者造成程序卡死奔溃!

do…while循环

do{
    //代码语句
}while(布尔表达式);

对于 while 语句而言,如果不满足条件,则不能进入循环。但有时候我们需要即使不满足条件,也至少执行一次。
do … while循环和while循环相似,不同的是,do … while循环至少会执行一次。

While和do…while的区别:

  • while先判断后执行。do…while是先执行后判断
  • do…while总是保证循环体会至少执行一次!

for循环

for循环语句是支持迭代的一种通用结构,是最有效、最灵活的循环结构。
for循环执行的次数是在执行前就确定的。语法格式如下:

for(初始化;布尔表达式;更新){
    //代码语句
};

增强for循环

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

声明语句:声明新的局部变量,该变量的类型必须和数组元素的类型匹配。其作用域限定在循环语句块,其值与此时数组元素的值相等。
表达式:表达式是要访问的数组名,或者是返回值为数组的方法。

打印九九乘法表

public class Demo02{
    public static void main(String[] args){
        int i,j;
        for(i=1;i<=9;i++){
            for(j=1;j<=i;j++){
                System.out.print(i+"*"+j+"="+(i*j)+"\t");
                }
            System.out.println();
        }
    }
}

输出:

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

关键字break,continue,goto

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

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

关于goto关键字

  • goto关键字很早就在程序设计语言中出现。尽管goto仍是Java的一个保留字,但并未在语言中得到正式使用;Java没有goto。然而,在break和continue这两个关键字的身上,我们仍然能看出一些goto的影子 — 带标签的break和continue。
  • “标签”是指后面跟一个冒号的标识符,例如:label​。
  • 对Java来说唯一用到标签的地方是在循环语句之前。而在循环之前设置标签的唯一理由是:我们希望在其中嵌套另一个循环,由于break和continue关键字通常只中断当前循环,但若随同标签使用,它们就会中断到存在标签的地方。

评论
成就一亿技术人!
拼手气红包6.0元
还能输入1000个字符
 
红包 添加红包
表情包 插入表情
 条评论被折叠 查看
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值