java写文件

简介:   1 使用FileWrite写文本文件  2   3   4 public static void useFileWriter(String fileName) throws IOException {  5     File file = new File(fileName);  6     ...
  1 使用FileWrite写文本文件
  2 
  3 
  4  public  static  void useFileWriter(String fileName)  throws IOException {
  5     File file =  new File(fileName);
  6     FileWriter fileWriter =  new FileWriter(file);
  7 
  8     fileWriter.write("it is a test");
  9 
 10     fileWriter.close();
 11 }
 12 
 13 
 14 
 15 使用BufferedWrite写文本文件
 16 
 17 
 18  public  static  void useBufferedWriter(String fileName)  throws IOException{
 19     File file =  new File(fileName);
 20     BufferedWriter bufferedWriter =  new BufferedWriter( new FileWriter(fileName));
 21 
 22     bufferedWriter.write("hello bufferedwrite");
 23 
 24     bufferedWriter.flush();
 25     bufferedWriter.close();
 26 }
 27 
 28 
 29 
 30 使用Files写文件,最简单
 31 
 32 
 33  public  static  void useJdk8(String fileName)  throws IOException {
 34     Files.write(Paths.get(fileName), "hello usejdk8".getBytes(), StandardOpenOption.CREATE);
 35 }
 36 
 37 
 38 私用FileOutputStream写文件
 39 
 40 
 41  public  static  void useFileOutputStream(String fileName)  throws IOException{
 42     File file =  new File(fileName);
 43 
 44     FileOutputStream fileOutputStream =  new FileOutputStream(file);
 45     fileOutputStream.write("hello fileoutputstream".getBytes());
 46 
 47     fileOutputStream.flush();
 48 
 49     fileOutputStream.close();
 50 }
 51 
 52 
 53 
 54 使用BufferedFileOutputStream写文件,速度最快,数据cache在jvm中,容易丢数据
 55 
 56 
 57  public  static  void useBufferedFileOutputStream(String fileName) {
 58     File file =  new File(fileName);
 59 
 60 
 61     BufferedOutputStream bufferedOutputStream =  null;
 62      try {
 63         bufferedOutputStream =  new BufferedOutputStream( new FileOutputStream(file));
 64 
 65         bufferedOutputStream.write("hello BufferedFileOutputStream".getBytes());
 66 
 67         bufferedOutputStream.flush();
 68     } catch(IOException e) {
 69 
 70 
 71     } finally {
 72          if(bufferedOutputStream!= null) {
 73              try {
 74                 bufferedOutputStream.close();
 75             }  catch (IOException e1) {
 76                  // TODO  do something
 77              }
 78         }
 79     }
 80 
 81 }
 82 
 83 
 84 
 85 使用RandomAccessFile写文件,速度最慢,直接刷盘
 86 
 87 
 88  public  static  void useRandomAccessFile(String fileName) {
 89     RandomAccessFile randomAccessFile =  null;
 90 
 91 
 92      try {
 93         randomAccessFile =  new RandomAccessFile(fileName, "rw");
 94         randomAccessFile.seek(15);  // 从第15个byte位置开始写, 原文件的第15个之后的字符会被覆盖一部分
 95          randomAccessFile.write("useRandomAccessFile".getBytes());
 96     }  catch (IOException e) {
 97         e.printStackTrace();
 98     } finally {
 99          if(randomAccessFile!= null) {
100              try {
101                 randomAccessFile.close();
102             }  catch (IOException e) {
103                 e.printStackTrace();
104             }
105         }
106 
107     }
108 }
109 
110 
111 
112 使用FileChannel写文件
113 
114 
115  public  static  void useFileChannel(String fileName) {
116 
117     FileChannel fileChannel =  null;
118      try {
119         FileChannel channel =  new FileOutputStream(fileName).getChannel();
120         channel.write(ByteBuffer.wrap("useFileChannel".getBytes()));
121     }  catch (IOException e) {
122         e.printStackTrace();
123     }  finally {
124          if(fileChannel!= null) {
125              try {
126                 fileChannel.close();
127             }  catch (IOException e) {
128                 e.printStackTrace();
129             }
130         }
131     }
132 }
133 
134 
135 
136 使用MappedByteBuffer写文件,速度快,OS级别内存映射
137 
138 
139  public  static  void useMappedByteBuffer(String fileName){
140 
141     RandomAccessFile randomAccessFile =  null;
142 
143      try {
144         randomAccessFile  =  new RandomAccessFile(fileName, "rw");
145         FileChannel fileChannel = randomAccessFile.getChannel();
146 
147 
148         String content = "useMappedByteBuffer";
149 
150         MappedByteBuffer mappedByteBuffer = fileChannel.map(FileChannel.MapMode.READ_WRITE, 0, content.getBytes().length);
151 
152         mappedByteBuffer.put(content.getBytes());    // mappedByteBuffer大小不能小于content的字节数
153 
154 
155     }  catch (IOException e) {
156         e.printStackTrace();
157     } finally {
158          if(randomAccessFile!= null) {
159              try {
160                 randomAccessFile.close();
161             }  catch (IOException e) {
162                 e.printStackTrace();
163             }
164         }
165     }
166 }         
若转载请注明出处!若有疑问,请回复交流!
目录
相关文章
|
4月前
|
Java
java小工具util系列5:java文件相关操作工具,包括读取服务器路径下文件,删除文件及子文件,删除文件夹等方法
java小工具util系列5:java文件相关操作工具,包括读取服务器路径下文件,删除文件及子文件,删除文件夹等方法
117 9
|
4月前
|
监控 Java 应用服务中间件
高级java面试---spring.factories文件的解析源码API机制
【11月更文挑战第20天】Spring Boot是一个用于快速构建基于Spring框架的应用程序的开源框架。它通过自动配置、起步依赖和内嵌服务器等特性,极大地简化了Spring应用的开发和部署过程。本文将深入探讨Spring Boot的背景历史、业务场景、功能点以及底层原理,并通过Java代码手写模拟Spring Boot的启动过程,特别是spring.factories文件的解析源码API机制。
141 2
|
26天前
|
存储 算法 Java
解锁“分享文件”高效密码:探秘 Java 二叉搜索树算法
在信息爆炸的时代,文件分享至关重要。二叉搜索树(BST)以其高效的查找性能,为文件分享优化提供了新路径。本文聚焦Java环境下BST的应用,介绍其基础结构、实现示例及进阶优化。BST通过有序节点快速定位文件,结合自平衡树、多线程和权限管理,大幅提升文件分享效率与安全性。代码示例展示了文件插入与查找的基本操作,适用于大规模并发场景,确保分享过程流畅高效。掌握BST算法,助力文件分享创新发展。
|
5月前
|
Java
Java“解析时到达文件末尾”解决
在Java编程中,“解析时到达文件末尾”通常指在读取或处理文件时提前遇到了文件结尾,导致程序无法继续读取所需数据。解决方法包括:确保文件路径正确,检查文件是否完整,使用正确的文件读取模式(如文本或二进制),以及确保读取位置正确。合理设置缓冲区大小和循环条件也能避免此类问题。
653 2
|
12天前
|
Java API 数据处理
深潜数据海洋:Java文件读写全面解析与实战指南
通过本文的详细解析与实战示例,您可以系统地掌握Java中各种文件读写操作,从基本的读写到高效的NIO操作,再到文件复制、移动和删除。希望这些内容能够帮助您在实际项目中处理文件数据,提高开发效率和代码质量。
18 0
|
3月前
|
人工智能 自然语言处理 Java
FastExcel:开源的 JAVA 解析 Excel 工具,集成 AI 通过自然语言处理 Excel 文件,完全兼容 EasyExcel
FastExcel 是一款基于 Java 的高性能 Excel 处理工具,专注于优化大规模数据处理,提供简洁易用的 API 和流式操作能力,支持从 EasyExcel 无缝迁移。
310 9
FastExcel:开源的 JAVA 解析 Excel 工具,集成 AI 通过自然语言处理 Excel 文件,完全兼容 EasyExcel
|
3月前
|
Java
java实现从HDFS上下载文件及文件夹的功能,以流形式输出,便于用户自定义保存任何路径下
java实现从HDFS上下载文件及文件夹的功能,以流形式输出,便于用户自定义保存任何路径下
122 34
|
2月前
|
前端开发 Java 开发工具
Git使用教程-将idea本地Java等文件配置到gitte上【保姆级教程】
本内容详细介绍了使用Git进行版本控制的全过程,涵盖从本地仓库创建到远程仓库配置,以及最终推送代码至远程仓库的步骤。
45 0
|
4月前
|
消息中间件 存储 Java
RocketMQ文件刷盘机制深度解析与Java模拟实现
【11月更文挑战第22天】在现代分布式系统中,消息队列(Message Queue, MQ)作为一种重要的中间件,扮演着连接不同服务、实现异步通信和消息解耦的关键角色。Apache RocketMQ作为一款高性能的分布式消息中间件,广泛应用于实时数据流处理、日志流处理等场景。为了保证消息的可靠性,RocketMQ引入了一种称为“刷盘”的机制,将消息从内存写入到磁盘中,确保消息持久化。本文将从底层原理、业务场景、概念、功能点等方面深入解析RocketMQ的文件刷盘机制,并使用Java模拟实现类似的功能。
85 3
|
4月前
|
Java 测试技术 Maven
Maven clean 提示文件 java.io.IOException
在使用Maven进行项目打包时,遇到了`Failed to delete`错误,尝试手动删除目标文件也失败,提示`java.io.IOException`。经过分析,发现问题是由于`sys-info.log`文件被其他进程占用。解决方法是关闭IDEA和相关Java进程,清理隐藏的Java进程后重新尝试Maven clean操作。最终问题得以解决。总结:遇到此类问题时,可以通过任务管理器清理相关进程或重启电脑来解决。

热门文章

最新文章