一. 引言,环境安装测试中的代码解析

 

 
 
1. HotSpot(TM) 64-bit Server VM(build 25.181-b13,mixed mode),这是多种
    HotSopt是多种虚拟机中的一种,是一个热点探测技术
    Hotspot虚拟机特点: 虚拟机会加载class文件,每次加载文件都会对该class文件进行标记,当标记到达一定的阀值会触发JIT机制
    JIT机制解释:即使编译,对频繁使用的CLass文件进行缓存,直接编译成虚拟机可以使用的文件,并进行缓存
 
 
2.Class文件是一个中间层文件, 虚拟机不能直接执行这个文件,虚拟机会将该文件编译成本地代码,
        HopSpot的两种运行机制:Server和Client, 采用两套机制来初始化自己   
        Client:更多的是基于桌面应用进行的虚拟机优化,B/S结构,客户端是可以并发的,为虚拟机分配的空间相对Servler来说要小很多,主要是为了在客户端环境中减少启动时间而优化;
        Server:分配给虚拟机的的空间比CLient大,优化方式也不同,处理大流量请求的时候效率比较高,在服务器环境中最大程度的提高执行效率
                缺点: 会造成空间浪费,它申请给虚拟机的内存空间比较大
 
 

二. Java虚拟机的基本结构

     
 
  1. 类加载子系统,参考笔记类加载器
 
  • 类加载器:
    • 读取Class文件,并将其转换成虚拟机可以使用的对象,将类的信息存到方法区中
 
 
  • 方法区:
    • 存储加载器传递的类的信息
    • 存放常量池信息,包括字符串和数字常量
 
 
  • java堆
    • 堆的区域是线程共享的
    • 堆得内存大小由jvm决定
    • 存储创建的对象信息
 
 
  • java栈
    • 每一个线程都有一个栈
    • 线程创建的时候创建
    • 保存帧空间
      • 举例,递归中,方法每次调用自己的时候,要进行压栈操作么,
        当一个新的方法压栈的时候原来的方法中还有其他地方没有运行完,
        还有一些数据需要保存, 这个保存点就叫做栈帧
         

        方法保存那些没运行的地方或者数据的节点叫做栈帧;

    • 保存局部变量,对象地址,方法,方法参数,还有方法的调用信息
 
 
  • 直接内存
    • 是物理内存的映射,大小不由虚拟机分配,理论上大小无限,实际按照物理内存的大小
    • 允许java的NIO模块直接调用
 
 
  • 垃圾回收系统
    • 作用在java堆,java栈,方法区中
    • 自动化,不需要手动,会自动检测,标识,寻找无用的对象并进行回收,全程静默
 
 
  • 本地方法栈
    • 存放本地方法
      • 本地方法指的是当前操作系统的api,虚拟机是需要本地系统的api才能够运行的

所以存在很多种不同的虚拟机;

 
  • pc寄存器
    • 主要用来分辨某一个线程正在操作的方法类型,并且被虚拟机选择调用虚拟机自己的方法
      • 如果当前线程正在执行的是本地操作系统的方法,会返回undefine
      • 如果在操作虚拟机方法,则返回该方法
        ps:虚拟机中不可能只存在一条线程,虚拟机中的线程任意状态一定是在执行方法;
 
 
  • 执行引擎
    • 执行引擎负责执行虚拟机的字节码,都采用 JIT (Just In Time) 即时编译,编译成机器码后再执行
 

三.总结

    jvm为每个新创建的线程都分配一个堆栈;
 
 

附件列表

https://www.cnblogs.com/lyuweigh/p/36e52fac9a5656dca084eedb06b09129.html

JVM虚拟机的大概了解(新人面试必看!)的更多相关文章

  1. 面试必看!靠着这份字节和腾讯的面经,我成功拿下了offer!

    准备 敲定了方向和目标后就开始系统准备,主要分为以下几个方面来准备. 算法题 事先已经看过别人的社招面经知道头条每轮技术面都有算法题,而这一块平时练习的比较少,校招时刷的题也忘记了很多.因此系统复习的 ...

  2. JAVA多线程面试必看(转载)

    JAVA多线程和并发基础面试问答 原文链接:http://ifeve.com/java-multi-threading-concurrency-interview-questions-with-ans ...

  3. 百度搜索 “Java面试题” 前200页(面试必看)

    前言 本文中的题目来源于网上的一篇文章<百度搜索 "Java面试题" 前200页>,但该文章里面只有题目,没有答案.因此,我整理了一些答案发布于本文.本文整理答案的原则 ...

  4. 【Python】【面试必看】Python笔试题

    前言 现在面试测试岗位,一般会要求熟悉一门语言(python/java),为了考验求职者的基本功,一般会出 2 个笔试题,这些题目一般不难,主要考察基本功.要是给你一台电脑,在编辑器里面边写边调试,没 ...

  5. linux c++ 服务器端开发面试必看书籍

    摘自别人博客,地址:http://blog.csdn.net/qianggezhishen/article/details/45951095 打算从这开始一本一本开始看 题外话: 推荐一个 githu ...

  6. 面试必看!凭借着这份 MySQL 高频面试题,我拿到了京东,字节的offer!

    前言 本文主要受众为开发人员,所以不涉及到MySQL的服务部署等操作,且内容较多,大家准备好耐心和瓜子矿泉水. 前一阵系统的学习了一下MySQL,也有一些实际操作经验,偶然看到一篇和MySQL相关的面 ...

  7. iOS面试必看

    转载:http://www.jianshu.com/p/5d2163640e26 序言 目前形势,参加到iOS队伍的人是越来越多,甚至已经到供过于求了.今年,找过工作人可能会更深刻地体会到今年的就业形 ...

  8. iOS面试必看,最全梳理

    序言 目前形势,参加到iOS队伍的人是越来越多,甚至已经到供过于求了.今年,找过工作人可能会更深刻地体会到今年的就业形势不容乐观,加之,培训机构一火车地向用人单位输送iOS开发人员,打破了生态圈的动态 ...

  9. iOS,面试必看,最全梳理

    序言 目前形势,参加到iOS队伍的人是越来越多,甚至已经到供过于求了.今年,找过工作人可能会更深刻地体会到今年的就业形势不容乐观,加之,培训机构一火车地向用人单位输送iOS开发人员,打破了生态圈的动态 ...

随机推荐

  1. spring boot集成多数据源过程以及错误

    https://blog.csdn.net/aa456aaxxx/article/details/80346703 出现BindingException错误  解决如下 https://my.osch ...

  2. 【转载】帧缓冲驱动程序分析及其在BSP上的添加

    原文地址:(四)帧缓冲驱动程序分析及其在BSP上的添加 作者:gfvvz 一.BSP修改及其分析   1. BSP中直接配置的四个寄存器 S3C6410数据手册的第14.5部分是显示控制器的编程模型部 ...

  3. 白话 P-value

    准备再尝试一下,用大白话叙述一遍统计推断中最基础的东西(假设检验.P值.……),算是把这段时间的阅读和思考做个梳理(东西不难,思考侧重在如何表述和展示).这次打算用一种“迂回的”表达方式,比如,本文从 ...

  4. ansible mysql模块的使用今年

    摘自: https://www.ibm.com/developerworks/cn/linux/1502_lih_ansible/

  5. laravel基础课程---6、请求(如何获取当前 HTTP 请求的实例)

    laravel基础课程---6.请求(如何获取当前 HTTP 请求的实例) 一.总结 一句话总结: 依赖注入:通过依赖注入的方式来获取当前 HTTP 请求的实例:public function sto ...

  6. python3 - 商品管理的程序,商品信息都存在一个json串里面

    商品管理的程序,商品信息都存在一个json串里面 1.查询商品信息 #校验商品是否存在 2.新增商品 # #校验商品是否存在 #校验价格是否合法 3.修改商品信息 ##校验商品是否存在 if chic ...

  7. 思科安全:加密流量威胁检测、加密流量威胁和恶意软件检测、识别无线干扰或威胁、Talos 情报源可加强对已知和新型威胁的防御、分布式安全异常检测

    思科DNA竞品比较工具 您的网络能够驱动数字化转型吗? 根据IDC调查,45%的受调研公司计划在未来两年内做好网络数字化的准备.查看数字化网络带来的结果和商业价值. 下载报告 思科 HPE 华为 Ar ...

  8. Apache Flink vs Apache Spark——感觉二者是互相抄袭啊 看谁的好就抄过来 Flink支持在runtime中的有环数据流,这样表示机器学习算法更有效而且更有效率

    Apache Flink是什么 Flink是一款新的大数据处理引擎,目标是统一不同来源的数据处理.这个目标看起来和Spark和类似.没错,Flink也在尝试解决 Spark在解决的问题.这两套系统都在 ...

  9. druid相关的时间序列数据库——也用到了倒排相关的优化技术

    Cattell [6] maintains a great summary about existing Scalable SQL and NoSQL data stores. Hu [18] con ...

  10. LinkedList_1.打印两个有序链表的公共部分

    思路: 实例化出两个链表($link_a, $link_b),比较连个链表当前元素的大小,谁小谁执行next()方法继续比较,当出现相当的时候把相等的值塞入数组$common里,当两个链表有一个元素比 ...