当前位置: 首页 > news >正文

政府网站建设集约化服务器h5制作

政府网站建设集约化服务器,h5制作,wordpress审批流,优化方案生物必修一答案ACM 模式的原理 在输入输出的时候,会先将输入输出的东西放在一个文件里,这个文件也叫做 IO 设备 为什么 Scanner 会慢 new 一个 Scanner ,在 Scanner 里面调用 next 的时候,程序会直接访问 IO 设备。在调用一个 next 的时候&…

ACM 模式的原理

在输入输出的时候,会先将输入输出的东西放在一个文件里,这个文件也叫做 IO 设备

为什么 Scanner 会慢

image.png|407

new 一个 Scanner ,在 Scanner 里面调用 next 的时候,程序会直接访问 IO 设备。在调用一个 next 的时候,只会在 IO 设备中拿出一个数,再将这个数返回程序

调用一个 next 就会访问一次 IO 设备,程序访问 IO 设备的速度特别慢。所以当输入的数据量很大的时候,就会多次访问这个 IO 设备,所以就会超时

为什么 System. out 会慢

Scanner 读取数据一样。当输出数据的时候,也是将数据一个一个拿到 IO 设备中。由于程序访问 IO 设备的速度特别慢,所以只要数据量稍微多一些,就会超时

快速读

自定义快读模板

class Read{StringTokenizer st = new StringTokenizer("");BufferedReader bf = new BufferedReader(new InputStreamReader(System.in));String next() throws IOException{while(!st.hasMoreTokens()){st = new StringTokenizer(bf.readLine());}return st.nextToken();}String nextLine() throws IOException{return bf.readLine();}int nextInt() throws IOException{return Integer.parseInt(next());}long nextLong() throws IOException{return Long.parseLong(next());}double nextDouble() throws IOException{return Double.parseDouble(next());}
}

模板解释

Java 在处理 IO 的时候,有两套标准:

  1. 字节流(System.in
  2. 字符流(带 Reader 或者 Writer

所以:

new InputStreamReader(System.in)

这里就是将字节流转换成了字符流

BufferedReader

它是一个带内存缓冲区的字符流。将要读取数据的时候,先将 IO 设备里面的数据一次性放到这个"内存缓冲区中"。然后 BufferedReader 再调用 next() 的时候,就是直接在内存缓冲区里面拿数据的

这对比 Scanner 调用 next 之后,一次一次地重复在 IO 设备中读取数据来说,BufferedReader 在调用 next 的时候,只需要读取一次内存缓冲区,就能读取到所有数据。

  • 直接从内存中拿数据,肯定是比访问 IO 设备要快得多的
    image.png

StringTokenizer

这里是字符串裁剪。本质是拿到缓冲区中的数据,然后裁剪成一个一个的字符串,最后再转换成你想要的 int、long、double 等类型…

我们在这个类中,new 了一个 BufferedReader,然后搞了一个字符串裁接


st = new StringTokenizer(bf.readLine());

我们这个字符串裁接传入的是 bf.readLine()

  • 意思是:我们直接在内存缓冲区中拿一行数据,然后交给字符串裁接对象image.png

return st.nextToken();

这个对象向调用 next 返回的时候是 nextToken

  • 意思是:我把拿出的一行字符串,裁接出来一个字符串,然后交给你

最后再将这个字符串转换成你需要的数据类型即可

为什么需要 while 循环

这里不需要 while 循环也行

String next() throws IOException{st = new StringTokenizer(bf.readLine());return st.nextToken();
}

直接读取一行数据,然后直接返回裁出来的字符串就行

但是这里为什么要加上 while 呢?

  • 因为有一些输入输出的题目,输入的数据不止只有一行
  • 当把第一行的数据一个一个裁完之后,你是要读取下一行数据的
  • 所以需要一个 while 循环判断,当后面没有数据了,就重新再读入一行,然后再返回新读入的一行的字符串

BufferedReader 相较于 System.in 快,就是因为他带了一个缓冲区。先把文件里面的数据刷新到缓冲区里面,然后在缓冲区里面拿一行一行的数据。随后通过 StringTokenizer 将读取的一行一行数据(bf.readLine())一个个地进行裁剪工作。当后面还有的行时候,就一个一个的裁;当后面没有行的时候,就再重新读一行,一个一个地裁

快速写

public class Main{public static PrintWiter out = new PrinterWriter(new BufferedWriter(new OutputStreamWriter(System.in)));public static Read in = new Read();public static void main(String[] args) throws IOException{int t = in.nextInt;double d = in.nextDouble;	//...out.close;}
}
  • 这里的方法名和 Scanner 一样,正常直接调用即可

模板解释

new BufferedWriter(new OutputStreamWriter(System.in))

这里是把字符流转换为字节流

此处的 BufferedReader 是在输出的时候,不直接将数据从 IO 设备输出到程序,而是先将数据输出到内存缓冲区中,然后程序在内存缓冲区中直接读取数据(与输入原理一致)

PrintWriter

其实 BufferedWriter 已经满足我们的需求了,为什么还要套一层 PrintWriter 呢?

  • 因为 BufferWriter 的输出方式不好写,而 PrintWriter 的输出方式和 System.out 是完全一样的(使用方式完全一样)
http://www.shuangfujiaoyu.com/news/27349.html

相关文章:

  • p2p网站建设应注意的问题厦门seo优化
  • 微信小程序怎么制作商城关键词优化设计
  • 自己做网站 微信杭州关键词优化测试
  • 新手想做网站赚钱优化营商环境心得体会1000字
  • 手机商城网站开发怎么进行网站推广
  • 招聘网站建设方案模板下载十大免费软文推广平台
  • 自己的域名可以转给做网站的账号吗外贸网站推广公司
  • 东莞专业网站营销微博营销软件
  • 重庆企业网站建设亚马逊的免费网站
  • 建设校园网站wbs计划营销策划案
  • 三级分销平台天津做优化好的公司
  • 不需要证件做网站如何制作一个个人网站
  • 网页制作基础教程第二版seo网站关键词排名提升
  • 购物商城网站制作郑州纯手工seo
  • 网站模板对seo的影响吗百度站长号购买
  • 焦作专业做网站公司百度框架户一级代理商
  • 呼市做网站怎么免费搭建自己的网站
  • 南京网站建设淘宝关键词优化推广排名
  • 成都区块链网站开发百度惠生活推广怎么收费
  • com表示商业网站做小程序公司哪家好
  • 大淘客做自己网站百度推广投诉中心
  • 多语言网站如何做uc浏览网页版进入
  • 厦门网站建设首选厦门一联网络指数搜索
  • 食品包装设计毕业论文seo是谁
  • 实用设计网站推荐网页设计页面
  • 淄博网站推广公司软文形式推广产品
  • 新媒体 网站建设百度 营销推广费用
  • 国外网站推广软件网络营销软文范例大全800
  • 做感恩网站的图片素材百度seo排名规则
  • 网站用亚马逊做标题会侵权吗关键词热度查询工具