从输入读取时,为什么Scanner比BufferedReader慢?

Gáb*_*kós 10 java bufferedreader java.util.scanner

我理解Scanner的优点,以及何时使用Scanner和BufferedReader.我读了一个不同的,但在一些类似的问题扫描仪与BufferedReader

当我从输入中读取时,为什么Scanner这么慢? 我认为它与扫描仪中有一个小缓冲区有关,但在这里我迷路了.最初的问题来自 Codechef,但我对该解决方案不感兴趣.

这是一个给定输入的代码示例:输入:

  • 7 3
  • 1
  • 51
  • 966369
  • 7
  • 9
  • 999996
  • 1

和代码

import java.io.BufferedReader;
import java.io.InputStreamReader;

public class Main {

    public static void main(String[] args) throws Exception {
        BufferedReader br = new BufferedReader(new InputStreamReader(System.in));
        String[] s = br.readLine().split(" "); 
        int numberOfLines = Integer.parseInt(s[0]);
        int divideNumber = Integer.parseInt(s[1]);
        int count = 0;

        for (int i = 0; i < numberOfLines; i++) {
            String number = br.readLine();
            if (number.length() < 11) {
                int num = Integer.parseInt(number);
                if (num % divideNumber == 0) {
                    count++;
                }
            } 
        }
        System.out.println(count);
    }
}
Run Code Online (Sandbox Code Playgroud)

如果我用扫描仪读取相同的代码,则速度很慢.

pet*_*rov 10

高级类/方法通常比低级类/方法慢.
以同样的方式你可以问为什么搜索regular expressions
搜索速度慢String.indexOf().其实我在这里看到过这样的问题.

你的类/方法越专业,它就能越好.
它只做了一件简单的事情,但它快速有效地完成.
更一般的类/方法可以做10-20个不同的事情,因此它们
更强大,但由于这个原因,它们更慢.

我在这里说的一般,我没有比较ScannerBufferedReader我自己.