博客
关于我
用户交互的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 权限整理记录
查看>>
mysql 权限登录问题:ERROR 1045 (28000): Access denied for user ‘root‘@‘localhost‘ (using password: YES)
查看>>
MYSQL 查看最大连接数和修改最大连接数
查看>>
MySQL 查看有哪些表
查看>>
mysql 查看锁_阿里/美团/字节面试官必问的Mysql锁机制,你真的明白吗
查看>>
MySql 查询以逗号分隔的字符串的方法(正则)
查看>>
MySQL 查询优化:提速查询效率的13大秘籍(避免使用SELECT 、分页查询的优化、合理使用连接、子查询的优化)(上)
查看>>
mysql 查询,正数降序排序,负数升序排序
查看>>
MySQL 树形结构 根据指定节点 获取其下属的所有子节点(包含路径上的枝干节点和叶子节点)...
查看>>
mysql 死锁 Deadlock found when trying to get lock; try restarting transaction
查看>>
mysql 死锁(先delete 后insert)日志分析
查看>>
MySQL 死锁了,怎么办?
查看>>
MySQL 深度分页性能急剧下降,该如何优化?
查看>>
MySQL 深度分页性能急剧下降,该如何优化?
查看>>
MySQL 添加列,修改列,删除列
查看>>
mysql 添加索引
查看>>
MySQL 添加索引,删除索引及其用法
查看>>
MySQL 用 limit 为什么会影响性能?
查看>>
MySQL 用 limit 为什么会影响性能?有什么优化方案?
查看>>
MySQL 用户权限管理:授权、撤销、密码更新和用户删除(图文解析)
查看>>