如何实现多个线程同时读取相同的inputstream_java015-IO流、多线程

第29次(IO流)

学习主题:IO流

学习目标:

1 掌握序列化和反序列化

2 掌握装饰器模式

  1. 对象流
    1. 为什么需要序列化?

序列化以后的对象可以保存到磁盘上,也可以在网络上传输,使得不同的计算机可以共享对象。(序列化的字节序列是与平台无关的)。

  1. 对象的序列化有哪些条件?

只有实现了Serializable接口的类的对象才可以被序列化。Serializable接口中没有任何的方法,实现该接口的类不需要实现额外的方法。

如果对象的属性是对象,属性对应类也必须实现Serializable接口

  1. 序列化和反列序列化
    1. 简述序列化与反序列化的内容?
  1. 序列化能保存的元素
  2. 只能保存对象的非静态成员变量
  3. 不能保存任何成员方法和静态的成员变量
  4. 不能保存transient成员变量
  5. 如果一个对象的成员变量是一个对象,这个对象的成员变量也会保存
  6. 串行化保存的只是变量的值,对于变量的任何修饰符,都不能保存
  7. 使用对象流把一个对象写到文件时不仅保证该对象是序列化的,而且该对象的成员对象也必须是可序列化的。
  8. 如果一个可序列化的对象包含对某个不可序列化的对象的引用,那么整个序列化操作将会失败,并且会抛出一个NotSerializableException。我们可以将这个引用标记transient,那么对象仍然可以序列化。
  1. 对象序列化的注意事项有哪些?
  1. 同一个对象多次序列化的处理
  2. 所有保存到磁盘中的对象都有一个序列化编号
  3. 序列化一个对象中,首先检查该对象是否已经序列化过
  4. 如果没有,进行序列化
  5. 如果已经序列化,将不再重新序列化,而是输出编号即可
  6. 如果不希望某些属性(敏感)序列化,或不希望出现递归序列
  7. 为属性添加transient关键字(完成排除在序列化之外)
  8. 自定义序列化(不仅可以决定哪些属性不参与序列化,还可以定义属性具体如何序列化)
  9. 序列化
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
在Java中,可以使用以下代码实现线读取同一个文件: ```java import java.io.BufferedReader; import java.io.FileReader; import java.io.IOException; public class MultiThreadFileReader implements Runnable { private final String filename; public MultiThreadFileReader(String filename) { this.filename = filename; } @Override public void run() { try (BufferedReader reader = new BufferedReader(new FileReader(filename))) { String line; while ((line = reader.readLine()) != null) { System.out.println(line); // 打印读取的文件内容 } } catch (IOException e) { e.printStackTrace(); } } public static void main(String[] args) { String filename = "input.txt"; // 创建多个线程并启动 Thread thread1 = new Thread(new MultiThreadFileReader(filename)); Thread thread2 = new Thread(new MultiThreadFileReader(filename)); Thread thread3 = new Thread(new MultiThreadFileReader(filename)); thread1.start(); thread2.start(); thread3.start(); // 等待所有线程执行完毕 try { thread1.join(); thread2.join(); thread3.join(); } catch (InterruptedException e) { e.printStackTrace(); } System.out.println("All threads finished reading file."); } } ``` 上述代码中,`MultiThreadFileReader` 类实现了 `Runnable` 接口,用于定义线程的执行逻辑。在 `run()` 方法中,使用 `BufferedReader` 读取文件的内容并打印出来。 在 `main()` 方法中,创建了多个线程并启动,每个线程都会调用 `MultiThreadFileReader` 类的构造方法,参数为要读取的文件名。然后使用 `start()` 方法启动线程。 最后,通过 `join()` 方法等待所有线程执行完毕,并输出提示信息。 需要注意的是,多个线程同时读取同一个文件并不会导致数据混乱或文件损坏的问题,因为读取操作是并发安全的。但是,考虑到文件的大小和读取速度,可能会出现文件内容的交错或乱序输出的情况。如果需要保证文件内容的顺序输出,可以在读取文件时进行适当的同步或排序处理。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值