ACM模式下Java输入输出函数为什么会超时?及解决方法

在线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(),可以直接打印数字,字符串等各种类型

代码说明

相关推荐
程序员老邢2 小时前
【产品底稿 04】商助慧 V1.1 里程碑:爬虫入库 + MySQL + Milvus 全链路打通
java·爬虫·mysql·ai·springboot·milvus
2601_950703942 小时前
Java安全编程与静态分析实战
java
唐叔在学习2 小时前
Python移动端应用消息提醒开发实践
开发语言·python
好家伙VCC2 小时前
**发散创新:基于Python与OpenCV的视频流帧级分析实战**在当前人工智能与计算机视觉飞速发展的背景下
java·人工智能·python·计算机视觉
SimonKing2 小时前
大V说’AI替代不了你’,但现实是——用AI的人正在替代你
java·后端·程序员
暴力求解2 小时前
C++ ---string类(三)
开发语言·c++
Pocker_Spades_A2 小时前
Python快速入门专业版(五十七)——POST请求与模拟登录:从表单分析到实战(以测试网站为例)
开发语言·python
一叶龙洲2 小时前
Java中使用模板引擎(FreeMarker / Velocity) + Word XML导出复杂Word
xml·java·word
道清茗2 小时前
【RH294知识点汇总】第 3 章 《 管理变量和事实 》1
开发语言·python