※ Jdk的目录结构

bin: 存放java的执行命令,详情参考java-command.txt文件,该目录应当保存到PATH变量中
Lib:是JDK工具用到的类库及其他文件,eg:tools.jar就包含了对开发工具的支持功能库
jre: java的运行环境(包含了java的类库和JVM虚拟机)
src.zip:jdk提供的类库的java代码
db:jdk自带的小型数据库
Include:包含c语言编写的文件

※ java的特点:

加速开发
写一次,到处运行
支持程序多线程的出来
动态的支持升级及编译
没有指针,不需要管理内存,纯粹的面相对象编程
提供gc的支持

垃圾回收器(GC)
垃圾回收器:java中有一个线程,专门负责JVM中垃圾内存的释放
垃圾:没有引用的内存节点
垃圾回收的算法
注意:垃圾回收有自己的算法,我们是不能控制垃圾回收机制的,虽然有和垃圾回收相关的方法:java.lang.System.gc() java.lang.Runtime.gc(),但是还是无法控制垃圾回收机制算法有(知道算法名字即可,不需要下去研究具体实现):标记-清除,复制,标记-整理,分代收集

※ Java程序执行的整个流程

java运行class文件中的主类 java运行class文件的命令_类加载器


Hello.java- -编译 ->Hello.class- ClassLoader装载- ->JVM- ->字节码验证

  • ->对字节码逐行解析- ->执行
  • ->JIT(即时编译) - ->执行

JVM装载.class 文件到内存的过程剖析(双亲委托机制)

启动级类加载器(Bootstrp ClassLoader)用C++语言写的,它是在Java虚拟机启动后初始化,它主要负责加载%JAVA_HOME%/jre/lib,
-Xbootclasspath参数指定的路径以及%JAVA_HOME%/jre/classes中的类

扩展级类加载器(Extension ClassLoader)用java语言写的,它负责将%JAVA_HOME%/jre/lib/ext或者由系统变量 java.ext.dir指定位置中的类库加载到内存中。开发者可以直接使用标准扩展类加载器。

本地类加载器(Applicaiton ClassLoader)用java语言写的,用于加载我们自己定义编写的类,它负责将系统类路径(CLASSPATH)中指定的类库加载到内存中。开发者可以直接使用系统类加载器。由于这个类加载器是ClassLoader中的getSystemClassLoader()方法的返回值,因此一般称为系统

(System)加载器

java运行class文件中的主类 java运行class文件的命令_java运行class文件中的主类_02

当源文件(.java文件)被编译成.class文件,且经过合法检测后,.class的运行过程如下:
依图中FirstStatic.class文件为例:
1)FirstStatic.class文件首先进入方法区。方法区用于首先处理.class文件。将.class文件中的静态的东西放入静态区属于类,只有一个),将非静态方法放入非静态区。
2)当主方法main中生成对象时,我们首先在堆里开辟一块区域用来放对象FirstStatic(),然后对非静态属性赋值。(静态属性早在静态区就赋过初值了)
3)方法的调用实际就是压栈的过程,调用静态方法时,将静态方法压入栈内,调用非静态方法时,将非静态方法压入栈内。(区别在与静态方法是在.class文件进入后就生成了,只有一个,调用时需考虑线程;非静态方法调用时,在生成对象之后,是在非静态方法中有一个方法镜像,不同对象调用时,通过镜像压入栈内不是同一个方法。)

※ 注:
先后顺序为:
1)静态的东西最先进入(直接存在了静态区)。
2)匿名代码块。
3)构造器(隐式默认无参构造器)生成对象赋值。
4)只有new时会在堆区开辟一块地方,所以只要有new,就会生成一个地址。
5)方法的调用是压栈的过程,方法没有地址。

※ 继承下生成子类对象时:
1)父子类里静态属性,覆盖默初始值,如有显示赋值,进行赋值;
2)父类的静态代码块,子类的静态代码块;
3)父类的非静态属性,覆盖默初始值,如有显示赋值,进行赋值;
4)父类的匿名代码块;
5)父类的构造器;
6)子类的非静态属性,覆盖默初始值,如有显示赋值,进行赋值;
7)子类的匿名代码块;
8)子类的构造器。

※ 双亲委托机制加载类的过程

当本地类加载器加载一个class时,它首先不会自己去尝试加载这个类,
而是把类加载请求委派给父类加载器扩展级类加载器去完成。

当扩展级类加载器加载一个class时,它首先也不会自己去
尝试加载这个类,而是把类加载请求委派给BootStrapClassLoader去完成。

如果扩展级类加载器加载失败,会使用扩展级类加载器来尝试加载;
若扩展级类加载器也加载失败,则会使用本地类加载器来加载,
如果本地类加载器也加载失败,则会报出异常ClassNotFoundException。

※ 生成jar包和解压jar包

-c 创建新的归档文件
-v 在标准输出中生成详细输出
-f 指定归档文件名
-x 解压归档文件
打包
jar -cvf Hello.jar Hello.class
解包
jar -xvf Hello.jar

※ 字节码验证过程

代码要符合JVM的规范
代码破不能破坏计算机的系统或者硬件
栈不能溢出
方法的参数类型要正确
类型转换要正确

※ JIT(即时编译)

通过代码的运行,基于2080规则基于算法
找出里面重复率比较高的代码存储起来,下次调用的时候不需要
在编译,直接执行。