一分三十一秒生成十亿行随机数的文本文件
程序短而简单,稍微可以说一下的是如果一行行写要三四分钟,采用了一次写十万行共写十万次的方式是提高效率的关键。
代码:
import java.io.BufferedWriter; import java.io.IOException; import java.io.PrintWriter; import java.nio.charset.Charset; import java.nio.file.Files; import java.nio.file.Path; import java.nio.file.Paths; import java.nio.file.StandardOpenOption; public class BigFileProducer { public static void main(String[] args) { long startMs=System.currentTimeMillis(); Path filepath=Paths.get("c:\\temp\\20200229.txt"); Charset u8set=Charset.forName("utf-8"); try(BufferedWriter shadowWriter=Files.newBufferedWriter(filepath, u8set,StandardOpenOption.CREATE)){ PrintWriter writer=new PrintWriter(shadowWriter); for(int i=0;i<10000;i++) { // 运行一万次 System.out.println("#"+i); writer.print(getTenThoasandNums()); // 每次十万行 } }catch(IOException ex) { ex.printStackTrace(); } long endMs=System.currentTimeMillis(); System.out.println("File:'"+filepath+"' created,time elapsed:"+ms2DHMS(startMs,endMs)); } private static String getTenThoasandNums() { StringBuilder sb=new StringBuilder(); for(int i=0;i<100000;i++) { sb.append(rnd(0,100)+"\n"); } return sb.toString(); } /** * get a random integer between min and max * @param min * @param max * @return */ private static int rnd(int min,int max) { return (int)(min+Math.random()*(max-min+1)); } /** * change seconds to DayHourMinuteSecond format * * @param startMs * @param endMs * @return */ private static String ms2DHMS(long startMs, long endMs) { String retval = null; long secondCount = (endMs - startMs) / 1000; String ms = (endMs - startMs) % 1000 + "ms"; long days = secondCount / (60 * 60 * 24); long hours = (secondCount % (60 * 60 * 24)) / (60 * 60); long minutes = (secondCount % (60 * 60)) / 60; long seconds = secondCount % 60; if (days > 0) { retval = days + "d" + hours + "h" + minutes + "m" + seconds + "s"; } else if (hours > 0) { retval = hours + "h" + minutes + "m" + seconds + "s"; } else if (minutes > 0) { retval = minutes + "m" + seconds + "s"; } else if(seconds > 0) { retval = seconds + "s"; }else { return ms; } return retval + ms; } }
输出:
#9997 #9998 #9999 File:'c:\temp\20200229.txt' created,time elapsed:1m31s369ms
生成文本文件片段:
52 87 44 62 99 33 53 50 32 58 13 62 84 52 4 95 57 34 40 33 76 38 73 19 86 63 35 5 30 25 37 75 58 59 34 48 82 96 21 76 7 6 97 24 12 69 84 92 22 35 46 68 67 87 62 45 77 84
--2020年2月29日--
【推荐】国内首个AI IDE,深度理解中文开发场景,立即下载体验Trae
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· Linux系列:如何用heaptrack跟踪.NET程序的非托管内存泄露
· 开发者必知的日志记录最佳实践
· SQL Server 2025 AI相关能力初探
· Linux系列:如何用 C#调用 C方法造成内存泄露
· AI与.NET技术实操系列(二):开始使用ML.NET
· 无需6万激活码!GitHub神秘组织3小时极速复刻Manus,手把手教你使用OpenManus搭建本
· C#/.NET/.NET Core优秀项目和框架2025年2月简报
· Manus爆火,是硬核还是营销?
· 终于写完轮子一部分:tcp代理 了,记录一下
· 【杭电多校比赛记录】2025“钉耙编程”中国大学生算法设计春季联赛(1)
2016-02-29 转帖:解决jquery.js在myeclipse中报错的问题
2016-02-29 T450的Fn lock
2016-02-29 【Canvas与艺术】绘制黄色三角辐射警示标志