zoukankan      html  css  js  c++  java
  • Java中从控制台输入的三种方式

    我们最熟悉的从控制台读取一个字符或者一个字符串都知道用Scanner,那么除了Scanner还有没有其他的呢,答案是有的,我们来看看。

    System.in.read()

    System.in.read()返回一个整型字节数据,该数据表示的是字节因此是Unicode的第一个字节或是字符的ASCII码值。该方法是从一个流中一个一个的读取数据,因此是一个迭代的过程。我们可以看出in是一个静态的流,因此在该程序中只有一个流,重复调用System.in.read()实际上是在遍历该流中的每一个字节数据。最常见的流是键盘输入流。我们可以在键盘中输入一个字符串(其中按下回车键代表了两个字符
    ,
    的ASCII码值是10,
    是13)。我们可以重复调用System.in.read()来读取从键盘输入的字符串中的字符所代表的字节(ASCII值)。
    public static void main(String[] args) throws IOException {
    		int s =  System.in.read();
    		//首先我在控制台输入一个1,但是有的同学会问为什么输出的是49呢,这不符合常理呀
    		/***
    		 * System.in.read接收的是字节0-255
    		 * 你输入个1以后,其实返回的是ASCII码,也就是49
    		 */
    		System.out.println(s);
    	}

    Scanner 这种方式也是大家最熟悉的一种方式

    我们直接看案例

    Scanner scanner = new Scanner(System.in);
    System.out.println(scanner.nextLine());

    我们来看第三种

    public static void main(String[] args)  {
    		//这里利用的缓冲流
    		BufferedReader br = new BufferedReader(new InputStreamReader(System.in ));
    		  String readData = null;
    		  System.out.print("输入数据:");
    		  try {
    			  readData = br.readLine();
    		  } catch (IOException e) {
    		   e.printStackTrace();
    		  }
    		  System.out.println("输入数据:"+readData); 
    	}

    以上部分内容来源于网络,有问题可以在下面评论,讨论技术问题可以私聊我。

    技术学习QQ群:213365178

  • 相关阅读:
    详解Windows注册表分析取证
    逻辑漏洞简单的分析
    文件解析漏洞汇总
    aspcms 这个靶场。。。
    WebBug靶场基础篇 — 03
    WebBug靶场基础篇 — 02
    WebBug靶场介绍篇 — 01
    漏洞挖掘中的常见的源码泄露
    PHP对象Object的概念
    从史上八大MySQL事故中学到的经验
  • 原文地址:https://www.cnblogs.com/c1024/p/11012037.html
Copyright © 2011-2022 走看看