摘要: 多任务,这是操作系统的一种能力,看起来可以在同一时刻运行多个程序。 并发执行的进程数目并不受限于CPU数目。 操作系统会为每个进程分配CPU时间片,给人并行处理的感觉。 多线程程序在更低一层扩展了多任务的概念:单个程序看起来在同时完成多个任务。 每个任务在一个线程中执行,线程是控制线程的简称。 如果 阅读全文
posted @ 2021-01-31 22:58 张三丰学Java 阅读(57) 评论(0) 推荐(0) 编辑
摘要: JDK的bin目录下有一些用于监视虚拟机运行状态和进行故障处理的工具, 可以分为三类: 商业授权工具 主要是JMC以及它使用到的JFR 正式支持工具 这类工具属于被长期支持的工具,不同平台、不同版本的JDK之间,这类工具会有差异,但是不会出现某个工具突然消失的情况。 实验性工具 这类工具没有技术支持 阅读全文
posted @ 2021-01-31 20:17 张三丰学Java 阅读(148) 评论(0) 推荐(0) 编辑
摘要: 直接内存并不是虚拟机运行时数据区的一部分,也不是规范中定义的内存区域 但是这部分内存也被频繁使用,而且也可能导致OutOfMemoryError 在JDK1.4中新添加了NIO类,引入了一种基于通道与缓冲区的I/O方式, 它可以使用Native函数库直接分配堆外内存, 然后通过一个存储在Java堆里 阅读全文
posted @ 2021-01-31 16:24 张三丰学Java 阅读(132) 评论(0) 推荐(0) 编辑
摘要: 运行时常量池是方法区的一部分。 Class文件中除了有类的版本、字段、方法、接口等描述信息外,还有一项信息是常量池表, 用于存放编译期生成的各种字面量与符号引用,这部分内容将在类加载后存放到方法区的运行时常量池中。 Java虚拟机对于Class文件每一部分(包括常量池)的格式都有严格规定,如每一个字 阅读全文
posted @ 2021-01-31 16:11 张三丰学Java 阅读(364) 评论(0) 推荐(0) 编辑
摘要: 方法区与Java堆一样,是各个线程共享的内存区域, 用于存储已经被虚拟机加载的类型信息、常量、静态变量、即时编译器编译后的代码缓存等数据。 虽然《Java虚拟机规范》中把方法区描述为堆的一个逻辑部分,但是它有个别名“非堆”(Non-Heap),用于和Java堆区分开来。 在JDK 8之前,许多Jav 阅读全文
posted @ 2021-01-31 14:53 张三丰学Java 阅读(204) 评论(0) 推荐(0) 编辑
摘要: Java堆是虚拟机所管理的内存中最大的一块。 Java堆是被所有线程共享的一块内存区域,在虚拟机启动时创建。 此内存区域的唯一目的就是存放对象实例,Java中几乎所有的对象实例都在这里分配内存。 随着Java的发展,即时编译技术的进步,Java对象实例分配在堆上慢慢变得不是那么绝对。 Java堆是垃 阅读全文
posted @ 2021-01-31 14:35 张三丰学Java 阅读(312) 评论(0) 推荐(0) 编辑