怎么入门Java?深入理解Java虚拟机(二

=========

1、编译器优化-泛型:

1、泛型出现之前存在的问题:

所有对象的类型都继承自Object,虚拟机只有到运行时才能知道这个Object具体是什么类型,在编译期是无法检查这个Object是否强制转型成功,会将ClassCaseException的风险转移到程序运行期。

2、泛型的作用:

通过泛型,编译器可以在编译阶段发现类型不一致的问题

3、泛型擦除:

将Java代码编译成Class文件,通过反编译发现泛型都不见了,被替换为原生类型,并插入强制转型的代码。


//泛型擦除前

List<String> list = new ArrayList<>();

list.add("hello");

System.out.println(list.get(0));

//泛型擦除后

List list1 = new ArrayList();

list1.add("hello");

System.out.println((String) list1.get(0));

2、运行期优化-代码优化

1、公共子表达式消除 在程序基本块中,如果一个表达式E已经被计算过了,下次再次使用的时候,如果表达式的变量值都没发生改变,就可以直接拿表达式的结果来代替E。


int x = 1;

int y = 2;

int z = x + y;

int w1 = x + y +2;

//编译器对公共子表达式(x+y)进行消除

int w2 = z + 2;

二、方法调用

======

1、解析

类加载解析节点,将一部分符号引用转化为直接引用。前提是程序运行前有可确定的调用版本,并且在运行期不可变。这些编译期可知、运行期不可变的方法调用就是解析。

2、静态分派和动态分派

1、静态分派:

根据静态类型来定位方法的分派叫做静态分派,发生在编译阶段。


//父类

public class Parent {

 

}

//子类

public class Son extends Parent {



}

//调用

public class MyTest {



  public void say(Parent parent) {

    System.out.println("parent say");

  }



  public void say(Son son) {

    System.out.println("son say");

  }



  public static void main(String[] args) {

    MyTest myTest = new MyTest();

    //实际类型为Parent

    Parent parent = new Parent();

    //实际类型为Son

    Parent son = new Son();

    myTest.say(parent);

    myTest.say(son);

  }

}

返回结果:

Parent为变量的静态类型,Son为实际类型。其中静态类型是在编译期可知的,而实际类型是在运行期确定下来的,编译器在编译阶段不知道某个对象的实际类型是什么,所以是用静态类型作为判定依据来选择使用哪个重载版本的,所以选择了say(Parent)作为调用目标。

2、动态分派


public class Parent {



  public void say() {

    System.out.println("parent....");

  }

}



public class Son extends Parent {



  public void say() {

    System.out.println("son....");

  }

}

//调用

Parent parent = new Parent();

Parent son = new Son();

parent.say();

son.say();

结果:

虚拟机根据实际类型的不同来分派方法

基本步骤:

  • 找到栈顶第一个元素所指向的对象实际类型

  • 如果找到对应方法,进行访问权限验证,通过则直接引用,不通过则抛出异常。

  • 否则,按照继承关系从下向上对其各个父类进行方法的搜索和验证过程。

  • 如果没方法,则抛AbstractMethodError异常。

三、并发

====

1、处理器、缓存、内存的关系

2、主内存、工作内存的关系

  • 线程的工作内存中保存了被该线程使用的变量的主内存的拷贝副本

  • 线程对变量的读取、赋值等操作是在工作内存中进行

  • 不同线程之间无法直接访问对方工作内存的变量,线程间变量值传递通过主内存来完成

3、内存间的交互操作

将变量从主内存拷贝到工作内存中,将工作内存同步到主内存中。定义了8中操作,每步操作都是原子的、不可再分。

最后

作为过来人,小编是整理了很多进阶架构视频资料、面试文档以及PDF的学习资料,针对上面一套系统大纲小编也有对应的相关进阶架构视频资料,如果**‘你’确定好自己未来的道路或者想学习提升自己技术栈、技术知识的小伙伴们可以点击这里来获取免费学习资料提升自己(全套面试文档、PDF、进阶架构视频)**


最后

作为过来人,小编是整理了很多进阶架构视频资料、面试文档以及PDF的学习资料,针对上面一套系统大纲小编也有对应的相关进阶架构视频资料,如果**‘你’确定好自己未来的道路或者想学习提升自己技术栈、技术知识的小伙伴们可以点击这里来获取免费学习资料提升自己(全套面试文档、PDF、进阶架构视频)**

[外链图片转存中…(img-PwfekA1w-1628151743188)]
[外链图片转存中…(img-eJlaJ5Wz-1628151743190)]

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值