博客
关于我
用户交互的Scanner对象
阅读量:63 次
发布时间:2019-02-25

本文共 1924 字,大约阅读时间需要 6 分钟。

基本语法

Scanner sc = new Scanner(System.in)

Scanner中通过next()或者nextLine()来获取用户输入的字符串,在读取之前还需要通过hasNext()hasNextLine()来判断用户是否有输入的情况

请看这两段代码:

第一段:使用next()获取用户输入

//获取键盘输入   Scanner scanner = new Scanner(System.in);   System.out.println("next()方法输入:");   //判断用户是否输入   if(scanner.hasNext()){          String str = scanner.next();       System.out.println("输入的内容为:" + str);   }   //关闭流   scanner.close();

测试:

在这里插入图片描述
第二段:使用nextLine()获取用户输入

Scanner sc = new Scanner(System.in);      System.out.println("nextLine()输入:");      if(sc.hasNextLine()){             String str = sc.nextLine();          System.out.println(str);      }      sc.close();

测试:

在这里插入图片描述
对比一下可以看出next()nextLine()的区别

next()不可以获取到空白,但是可以忽视开头的空白,而nextLine()可以显示出空白

Scanner进阶

Scanner类中定义了很多方法,比如用户输入时可以是不同类型的数字,Scanner都可以检测出来:

//获取键盘输入 		Scanner scanner = new Scanner(System.in);        int i = 0;        float f = 0.0f;        System.out.println("输入整数:");        //判断是否是整数        if(scanner.hasNextInt()){               i = scanner.nextInt();            System.out.println("整数数据:" + i);        } else {               System.out.println("输入的不是整数!");        }        System.out.println("请输入小数:");		//判断是否是小数        if(scanner.hasNextFloat()){               f = scanner.nextFloat();            System.out.println("小数:" + f);        } else{               System.out.println("输入的不是小数!");        }

练习:输入多个数字,求总和和平均数,没输入一个数字就回车进行确认,若输出的不是数字则得出结果。

public static void main(String[] args) {           Scanner scanner = new Scanner(System.in);        double sum = 0;        //当前第几个数        int m = 0;        //不满足条件直接跳出循环        while (scanner.hasNextDouble()){               //获得输入的值            double nextDouble = scanner.nextDouble();            m++;            sum = sum + nextDouble;            System.out.println("你输入了" + m + "个数字,当前结果sum=" + sum);        }        System.out.println(m + "个数字和为:" + sum);        System.out.println(m + "个数的平均值为:" + sum/m);        scanner.close();        }

在这里插入图片描述

转载地址:http://erv.baihongyu.com/

你可能感兴趣的文章
MySQL中的ON DUPLICATE KEY UPDATE详解与应用
查看>>
mysql中的rbs,SharePoint RBS:即使启用了RBS,内容数据库也在不断增长
查看>>
mysql中的undo log、redo log 、binlog大致概要
查看>>
Mysql中的using
查看>>
MySQL中的关键字深入比较:UNION vs UNION ALL
查看>>
mysql中的四大运算符种类汇总20多项,用了三天三夜来整理的,还不赶快收藏
查看>>
mysql中的字段如何选择合适的数据类型呢?
查看>>
MySQL中的字符集陷阱:为何避免使用UTF-8
查看>>
mysql中的数据导入与导出
查看>>
MySQL中的时间函数
查看>>
mysql中的约束
查看>>
MySQL中的表是什么?
查看>>
mysql中穿件函数时候delimiter的用法
查看>>
Mysql中索引的分类、增删改查与存储引擎对应关系
查看>>
Mysql中索引的最左前缀原则图文剖析(全)
查看>>
MySql中给视图添加注释怎么添加_默认不支持_可以这样取巧---MySql工作笔记002
查看>>
Mysql中获取所有表名以及表名带时间字符串使用BetweenAnd筛选区间范围
查看>>
Mysql中视图的使用以及常见运算符的使用示例和优先级
查看>>
Mysql中触发器的使用示例
查看>>
Mysql中设置只允许指定ip能连接访问(可视化工具的方式)
查看>>