在线OJ的两种模式
1.ACM模式:全空白,需要自己写框架,写输入和输出
2.核心代码模式:只需完成所给函数
在ACM模式下,如果输入输出的数据量级过大,运行时就会超时,即使代码正确也提交不了
那么为什么会超时?
因为Scanner/System.out进行输入输出时,都会频繁的和硬盘/控制台这类IO设备交互
Scanner的工作方式:每次都直接访问设备。
1.每调用一次Scanner.next(),都会直接向控制台/文件发起一次IO请求,读取一个数据。因为Scanner每次读取数据都和系统交互,效率极低,在数据量级大时输入会非常慢,拖慢运行速度
2.System.in属于字节流。按字节读取,不适合直接读中文、字符串
3.没有缓冲区:每次读都直接访问IO设备,速度慢
4.不能直接按行/按单词读取:必须自己处理字节------>字符的转换
System.out.println()的工作方式:每次输出都直接写设备
每调用一次System.out.println()都会把一行数据直接写到控制台/文件里。每次调用都要与系统进行交互,频繁调用会造成效率极低
解决方法:使用缓冲区。在输入时使用BufferedReader一次性批量将大量数据读入内存缓存;输出时使用PrintWriter/BufferedWriter先把数据累计到内存缓存,最终一次性输出到设备,大幅减少设备交互次数,提升运行速度
为什么这样就能提升运行速度?
输入:BufferedReader+缓冲区

1.用InputStreamReader将字节流------>字符流
2.再用BufferedReader包装,提供缓冲区
3.读取一整行数据
输出:PrinterWriter/BufferedWriter+缓冲区

1.用OutoutStreamWriter把System.out这个字节流转换为字符流
2.再用BufferedWriter给字符流提供缓冲区(解决频繁交互问题)
3.再包装PrintWriter,给缓冲流加上便捷的打印方法(BufferedWriter只能写字符串,不能直接打印数字,不能直接换行,必须写为:
,而PrintWriter提供了print()/println()/printf(),可以直接打印数字,字符串等各种类型
)