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

代码说明

相关推荐
亦暖筑序23 分钟前
Java 8老系统Browser Agent实战:三层拦截把AI操作后台变成可审计流程
java·后端·设计模式
用户298698530143 小时前
Java 实现 Word 文档加密与权限解除
java·后端
Yeats_Liao4 小时前
14:Servlet中的页面跳转-Java Web
java·后端·架构
未秃头的程序猿4 小时前
告别"if-else地狱"!Java 21模式匹配,代码优雅了10倍
java·后端·面试
鹤望兰6755 小时前
字节跳动国际支付-后端开发-三面面经
java
Flittly5 小时前
【AgentScope Java新手村系列】(14)人机交互
java·spring boot·spring
RainCity5 小时前
Java Swing 自定义组件库分享(十二)
java·笔记·后端
吃饱了得干活21 小时前
Spring Cloud Gateway 微服务网关:路由、断言、过滤器
java·spring cloud
lwx572801 天前
探秘InnoDB:搞懂它的内存、线程、磁盘与日志刷盘策略
java·后端
Flynt1 天前
从Spring Boot 4.0升到4.1,我在Maven和gRPC上栽了跟头
java·spring boot·后端