最近在看Brian Goetz 的<<Java并发实战>>,这本书有两个版本,电子工业出版社的译本很糟糕,建议使用机械工业出版社出版出版的书籍.
在看到第三四章的时候突然想到了多线程读写文件,同时遇到一些书中没有的问题
1, 如何保证组合对象的安全性?
2, 如何判断不变性的约束条件
3, 如何不通过synchronized关键字和锁进行同步处理?
下面是一段代码, 用来从source 读取数据,通过多线程写入target文件中
思路:
1, 如何read/write文件?
2, 如何设计Reader类?
3, Reader类的是否需要状态来描述? 状态变量如何同步?
4, 如何保证当前Thread可以准确地读取当前segment?
代码综述:

本文探讨了在Java中如何实现并发读写文件,重点在于使用RandomAccessFile以确保线程安全。通过创建Reader类,将文件划分为多个segment,并使用AtomicLong来同步线程对文件状态的访问。代码示例展示了如何读取源文件的不同部分,通过多线程写入目标文件,以及处理最后一个不完整segment的方法。

786

被折叠的 条评论
为什么被折叠?



