深入分析 Java I/O 的工作机制

简介: 版权声明:本文为博主原创文章,未经博主允许不得转载。 https://blog.csdn.net/a724888/article/details/61916185 深入分析 Java I/O 的工作机制总结:1 I/O接口分为字节型和字符型,通过inputstreamreader进行转换。
版权声明:本文为博主原创文章,未经博主允许不得转载。 https://blog.csdn.net/a724888/article/details/61916185

深入分析 Java I/O 的工作机制



总结:

1 I/O接口分为字节型和字符型,通过inputstreamreader进行转换。

2I/O访问方式
2.1 磁盘I/O:标准访问文件方式:从 用户地址空间经过内核空间 物理磁盘 再到
2.2 直接I/O:不经过内核空间直接访问磁盘,但是不经过缓存,速度较慢。
2.3 内存映射方式访问,内存某一块区域与磁盘关联,数据共享

2.4 同步、异步、阻塞、非阻塞:
同步异步注重调用的方式,
同步在调用时会等待调用返回结果。

异步会直接返回,并等所调用的对象进行回调。
阻塞非阻塞注重结果的返回

阻塞会一直挂起等待返回值。
非阻塞可以在等待时做其他事,隔一段时间再来查看结果。

3、java序列化技术(java io):实现serializable接口。与cloneable接口的区别是浅拷贝和深拷贝的区别。
要点有:
3.1父类实现serializable接口,子类可序列化
3.2、子类实现serializable接口,父类没有,父类属性不能序列化
3.3、若序列化的对象持有其他对象引用,其他对象也要序列化。
3.4、反序列化时id若被修改则会失败。
3.5transient关键字指定某属性不被序列化。


4、网络I/O基于socket
4.1基础是tcp协议
4.2影响传输的因素:带宽、传输距离、tcp拥塞控制
4.3socket包含本地地址,远程地址,端口号。
4.4socket创建时,操作系统为其分配一个缓冲区,用于数据读取与写入。
sendq队列用于写入数据到outputstream,recvq队列用于读取数据到inputstream。
队列满时会阻塞,队列空时会等待,即生产消费者的阻塞队列模式。

5NIO:解决BIO的困境,采用非阻塞io,
1使用selector静态工厂创建一个选择器。
2创建一个服务端的channel绑定到一个socket对象,把他注册到选择器上,selector可以监听channel中所有通信信道的事件。
3将通信信道设为非阻塞,使线程可以在信道之间切换。
4通过selectedkey来检查已注册选择器上的信道是否有事件发生,如果有事件发生,返回所有selectedkey,通过channel方法得到通信信道对象,通过buffer进行数据读取。
5、tomcat和jetty使用一个线程监听客户端请求,是阻塞的,另一个线程负责处理请求,是非阻塞的。
6、线程在得知事件发生后,找到对应的buffer进行数据交互,并且可以与多个buffer交互,是非阻塞的。
7、buffer的数据访问方式:经过socket缓冲再复制到buffer,或者直接操作系统缓冲区(通过directbuffer操作非jvm堆内存)每次创建或释放需要调用一次system.gc。可能引起内存泄漏。

6、IO调优
1磁盘优化
2tcp参数优化
3网络io优化:减少交互、减少数据返回、减少编码。

适配器和装饰者:
适配器把一个接口转接成另一个接口。
而装饰者只是扩展原接口功能。


原文链接:http://blog.csdn.net/a724888/article/details/61916885



相关文章
|
6天前
|
Java 数据库连接 开发者
Java的Shutdown Hook机制:优雅地关闭应用程序
Java的Shutdown Hook机制:优雅地关闭应用程序
22 1
|
6天前
|
Java 程序员 开发者
深入理解Java并发编程:线程同步与锁机制
【4月更文挑战第30天】 在多线程的世界中,确保数据的一致性和线程间的有效通信是至关重要的。本文将深入探讨Java并发编程中的核心概念——线程同步与锁机制。我们将从基本的synchronized关键字开始,逐步过渡到更复杂的ReentrantLock类,并探讨它们如何帮助我们在多线程环境中保持数据完整性和避免常见的并发问题。文章还将通过示例代码,展示这些同步工具在实际开发中的应用,帮助读者构建对Java并发编程深层次的理解。
|
5天前
|
缓存 安全 Java
7张图带你轻松理解Java 线程安全,java缓存机制面试
7张图带你轻松理解Java 线程安全,java缓存机制面试
|
5天前
|
NoSQL 算法 Java
【redis源码学习】持久化机制,java程序员面试算法宝典pdf
【redis源码学习】持久化机制,java程序员面试算法宝典pdf
|
6天前
|
Java 关系型数据库 MySQL
【Java Spring开源项目】新蜂(NeeBee)商城项目运行、分析、总结
【Java Spring开源项目】新蜂(NeeBee)商城项目运行、分析、总结
156 4
|
6天前
|
消息中间件 安全 前端开发
字节面试:说说Java中的锁机制?
Java 中的锁(Locking)机制主要是为了解决多线程环境下,对共享资源并发访问时的同步和互斥控制,以确保共享资源的安全访问。 锁的作用主要体现在以下几个方面: 1. **互斥访问**:确保在任何时刻,只有一个线程能够访问特定的资源或执行特定的代码段。这防止了多个线程同时修改同一资源导致的数据不一致问题。 2. **内存可见性**:通过锁的获取和释放,可以确保在锁保护的代码块中对共享变量的修改对其他线程可见。这是因为 Java 内存模型(JMM)规定,对锁的释放会把修改过的共享变量从线程的工作内存刷新到主内存中,而获取锁时会从主内存中读取最新的共享变量值。 3. **保证原子性**:锁
20 1
|
6天前
|
安全 Java 数据安全/隐私保护
Java一分钟之-Java反射机制:动态操作类与对象
【5月更文挑战第12天】本文介绍了Java反射机制的基本用法,包括获取Class对象、创建对象、访问字段和调用方法。同时,讨论了常见的问题和易错点,如忽略访问权限检查、未捕获异常以及性能损耗,并提供了相应的避免策略。理解反射的工作原理和合理使用有助于提升代码灵活性,但需注意其带来的安全风险和性能影响。
24 4
|
6天前
|
Java
【JAVA基础篇教学】第十三篇:Java中I/O和文件操作
【JAVA基础篇教学】第十三篇:Java中I/O和文件操作
|
6天前
|
Java 数据安全/隐私保护
java中异常处理机制
java中异常处理机制
15 1
|
6天前
|
Java
【Java多线程】分析线程加锁导致的死锁问题以及解决方案
【Java多线程】分析线程加锁导致的死锁问题以及解决方案
26 1