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

 

 
 
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. uboot 从sd卡加载文件并烧写到nand flash

    uboot下可以从用tftp和nfs加载文件. 但是现在有个开发板配套uboot网络功能出现异常,执行ping命令就会导致开发板重启,只能选择先从sd卡加载文件 启动开发板,任意键进入uboot,然后 ...

  2. 排序List集合

    这两天写代码过程中遇到一个需求,需要按照某个字段排序List集合,自己实现了一半,发现网上有个更好的版本,就采用了这个,记录下来. 使用这个工具类要注意一个就是 如果你按照age 字段排序,那么age ...

  3. 如何在Mac的Finder中显示/usr、/tmp、/var等隐藏目录

    原文链接: http://blog.csdn.net/yhawaii/article/details/7435918 Finder中默认是不显示/usr./tmp./var等隐藏目录的,通过在终端中输 ...

  4. Java并发模型(一)

    学习资料来自http://ifeve.com/java-concurrency-thread-directory/ 一.多线程 进程和线程的区别: 一个程序运行至少一个进程,一个进程至少包含一个线程. ...

  5. hdu-1542 Atlantis(离散化+线段树+扫描线算法)

    题目链接: Atlantis Time Limit: 2000/1000 MS (Java/Others)     Memory Limit: 65536/32768 K (Java/Others) ...

  6. 网络编程学习笔记-浅析socket

    一.问题的引入——socket的引入是为了解决不同计算机间进程间通信的问题 .socket与进程的关系 ).socket与进程间的关系:socket 用来让一个进程和其他的进程互通信息(IPC),而S ...

  7. 解决系统存在大量TIME_WAIT状态的连接

    系统存在大量TIME_WAIT状态的连接,通过调整内核参数解决, vi /etc/sysctl.conf 编辑文件,加入以下内容:net.ipv4.tcp_syncookies = 1net.ipv4 ...

  8. AtCoder Beginner Contest 104

    A - Rated for Me Time Limit: 2 sec / Memory Limit: 1024 MB Score : 100100 points Problem Statement A ...

  9. P1912 [NOI2009]诗人小G[决策单调性优化]

    地址 n个数划分若干段,给定$L$,$p$,每段代价为$|sum_i-sum_j-1-L|^p$,求总代价最小. 正常的dp决策单调性优化题目.不知道为什么luogu给了个黑题难度.$f[i]$表示最 ...

  10. Docker入门(二):安装/卸载

    这个<Docker入门系列>文档,是根据Docker官网(https://docs.docker.com)的帮助文档大致翻译而成.主要是作为个人学习记录.有错误的地方,Robin欢迎大家指 ...