一.基本结构 类加载器:在 JVM 启动时或在类运行时需要将类的字节码信息加载到 JVM 内存区域中. 执行引擎:负责执行字节码信息中包含的字节码指令,相当于实际机器上的 CPU. 内存区域:也被称为运行时数据区.将内存划分为多个区域,模拟实际机器上的储存.记录和调度功能模块.因为执行引擎在执行一段程序时需要储存一些东西(如操作码需要的操作数,操作码的执行结果需要保存),而且类的字节码和对象等信息都需要在执行引擎执行前就准备好. 本地方法接口:主要是调用C或C++实现的本地方法及返回结果. 如图…
1.类加载时机 类的整个生命周期包括了:加载( Loading ).验证( Verification ).准备( Preparation ).解析( Resolution ).初始化( Initialization ).使用( Using )和卸载( Unloading )七个阶段.其中验证.准备和解析三个部分统称为连接( Linking ),这七个阶段的发生顺序如下图. 上图中,加载.验证.准备.初始化和卸载这五个阶段的顺序是确定的,类的加载过程必须按照这种顺序开始.但解析阶段不一定:它在某些…
.2.1 java的I/O类库的基本架构 I/O的机器获取和交换信息的主要渠道,在当今数据大爆炸时代,I/O问题尤其突出,很容易成为一个性能瓶颈,Java在I/O上也一直做持续的优化,现在也引入了NIO,提升了I/O的性能. java.io下大概有80个类,主要分为以下4种: ◉  基于字节操作的I/O接口:InputStream 和 OutputStream InputStream和OutputStream的类层次结构. 写网络其实也是写文件,只是多了一步,就是让底层操作系统再将数据传送到其他…
java的I/O操作类在包java.io下,大致分成4组: 所有文件的存储都是字节(byte)的储存,在磁盘上保留的并不是文件的字符而是先把字符编码成字节,再存储这些字节到磁盘.在读取文件时,也是一个字节一个字节读取. 字节流可以用于任何类型的对象,包括二进制对象:而字符流只能处理字符或者字符串 字节流是最基本的,所有的InputStrem和OutputStream的子类都是,主要用在处理二进制数据,它是按字节来处理的. 但实际中很多的数据是文本,又提出了字符流的概念,它是按虚拟机的encode…
注意:一下内容纯属个人理解,如有错误,欢迎批评指正. (90度弯腰)谢谢. java在JVM上的运行过程: 1,编辑好的java代码(IDE无报错,测试运行无错误): 2,java源代码通过javac编译成class文件(字节码文件,全是二进制数据,是供神看的东西): 3,class文件加载到JVM上,继续二次编译(或者说上次的根本就不算编译,就是一格式转换),进行平台格式化(这也是java广告的来源): 4,格式化后的文件,就可以在相应的平台上进行运行了(机器直接读取格式化后的二进制文件,也就…
Java 的 I/O 类库的基本架构 I/O 问题是任何编程语言都无法回避的问题,可以说 I/O 问题是整个人机交互的核心问题,因为 I/O 是机器获取和交换信息的主要渠道.在当今这个数据大爆炸时代,I/O 问题尤其突出,很容易成为一个性能瓶颈.正因如此,所以 Java 在 I/O 上也一直在做持续的优化,如从 1.4 开始引入了 NIO,提升了 I/O 的性能.关于 NIO 我们将在后面详细介绍. Java 的 I/O 操作类在包 java.io 下,大概有将近 80 个类,但是这些类大概可以…
I/O 问题可以说是当今互联网 Web 应用中所面临的主要问题之一,因为当前在这个海量数据时代,数据在网络中随处流动.这个流动的过程中都涉及到 I/O 问题,可以说大部分 Web 应用系统的瓶颈都是 I/O 瓶颈.本文的目的正是分析 I/O 的内在工作机制,你将了解到:Java 的 I/O 类库的基本架构:磁盘 I/O 工作机制:网络 I/O 的工作机制:其中以网络 I/O 为重点介绍 Java Socket 的工作方式:你还将了解到 NIO 的工作方式,还有同步和异步以及阻塞与非阻塞的区别,最…
3.网络I/O的工作机制 前言:数据从一台主机(服务端)发送到网络中的另一台主机(客户端)需要经过很多步骤:首先需要有相互沟通的意向.其次要有能够沟通的物理渠道(物理链路):是通过电话,还是直接面对面交流.再次,双方见面时语言要能够交流,而且双方说话步调要一致,明白什么时候该自己说话,什么时候该对方说话(通信协议).所以下面要讲一下通信协议和如何完成数据传输. 什么是通信协议:通信协议其实就是一种规则和约定.就是两者想要交流必须要知道那种方式交流,什么时候去交流,交流什么内容,这就是通信协议.…
2.磁盘I/C工作机制 2.1几种访问文件的方式 内核空间和用户空间:内核空间是内核使用,用户空间是应用程序使用:除非编译内核要考虑内核空间,其余情况都可以按照用户空间处理.将用户空间和内核空间置于这种非对称访问机制下有很好的安全性. 读取和写入文件I/O操作都调用系统提供的接口,因为磁盘设备是由操作系统管理的,应用程序要访问物理设备只能通过系统调用的方式来工作.读和写分别对应read和write两个系统调用.而只要是系统调用就可能存在内核空间地址和用户空间地址切换的问题,这是操作系统为了保护系…
此篇博客看至许令波的深入分析javaWeb内幕书籍, 此篇博客写的是自己看完之后理解的重点内容,加一些理解,希望对你有帮助. 1.Java的I/O类库的基本架构 先说一下什么是类库:可以说是类的集合,类库包括接口.抽象类.具体类等. I/O是机器获取和交互信息的主要渠道. java在I/O上也一直在做持续的优化,在1.4版开始引入了NIO,提升了I/O的性能. java的I/O操作类在包java.io下,大概有80个类左右,这些类大概可以分为如下4组: 基于字节操作的I/O接口:InputStr…