首页
学习
活动
专区
圈层
工具
发布
50 篇文章
1
大数据必学Java基础(一):Java体系结构、特性和优势
2
大数据必学Java基础(二):Java核心机制
3
大数据必学Java基础(三):JAVA环境准备-->JDK
4
大数据必学Java基础(四):安装notepad++,配置path环境变量
5
大数据必学Java基础(五):第一段程序
6
大数据必学Java基础(六):程序中常见问题和编译方式
7
大数据必学Java基础(七):扩展环境变量
8
大数据必学Java基础(八):简单介绍API和注释
9
大数据必学Java基础(九):JDK,JRE,JVM的区别
10
大数据必学Java基础(十):标识符和关键字
11
大数据必学Java基础(十一):变量和常量
12
大数据必学Java基础(十二):基本数据类型
13
大数据必学Java基础(十三):基本数据类型的转换
14
大数据必学Java基础(十四):Java中的运算符
15
大数据必学Java基础(十五):算术运算符
16
大数据必学Java基础(十六):赋值运算符
17
大数据必学Java基础(十七):关系运算符和逻辑运算符
18
大数据必学Java基础(十八):条件运算符和位运算符
19
大数据必学Java基础(十九):运算符总结
20
大数据必学Java基础(二十):流程控制的引入和if语句介绍
21
大数据必学Java基础(二十一):Switch多分支结构介绍
22
大数据必学Java基础(二十二):循环结构
23
大数据必学Java基础(二十三):方法的定义/调用/重载
24
大数据必学Java基础(二十四):数组的引入和学习
25
大数据必学Java基础(二十五):数组的三种初始化方式
26
大数据必学Java基础(二十六):数组的应用题
27
大数据必学Java基础(二十七):详述main方法和了解可变参数
28
大数据必学Java基础(二十八):Arrays工具类和数组的复制操作
29
大数据必学Java基础(二十九):二维数组
30
大数据必学Java基础(三十):IDEA的使用介绍
31
大数据必学Java基础(三十一):IDEA模板的使用
32
大数据必学Java基础(三十二):IDEA中的断点调试
33
大数据必学Java基础(三十三):面向对象介绍
34
大数据必学Java基础(三十四):面向对象内存分析
35
大数据必学Java基础(三十五):深入了解关键词this
36
大数据必学Java基础(三十六):深入了解关键词static
37
大数据必学Java基础(三十七):代码块讲解
38
大数据必学Java基础(三十八):包和import讲解
39
大数据必学Java基础(三十九):面向对象三大特性之一封装(Encapsulation)
40
大数据必学Java基础(四十):面向对象三大特性之一继承(Inheritance)
41
大数据必学Java基础(四十一):面向对象三大特性之一多态(Polymorphism)
42
大数据必学Java基础(四十二):Final关键词讲解
43
大数据必学Java基础(四十三):抽象类和抽象方法讲解
44
大数据必学Java基础(四十四):接口讲解
45
大数据必学Java基础(四十五):JDK1.8以后的接口新增内容
46
大数据必学Java基础(四十六):内部类和面向对象项目实战
47
大数据必学Java基础(四十七):异常的讲解
48
大数据必学Java基础(四十八):包装类和日期类的讲解
49
大数据必学Java基础(四十九):Math类和Random类的讲解
50
大数据必学Java基础(五十):String类和StringBuilder类的讲解

大数据必学Java基础(二):Java核心机制

​Java核心机制

一、垃圾收集机制

垃圾收集的目的在除不再使用的对象,当对象建立的时候垃圾收集期,就开始监控对象的动态情况,垃圾收集主要是对内存的释放。创建对象的时候申请一个空间

  • 不再使用的内存空间应回收---》垃圾收集;
  • Java消除了程序员回收无用内存空间的职责;提供一种系统级线程跟踪

存储空间的分配情况。在JVM的空闲时,检查并释放可被释放的存储器空间;相比c++,开发人员负责要自己收回无用内存。

  • 垃圾收集在Java程序运行过程中自动进行,程序员无法精确控制和干预;
  • GC的自动回收,提高了内存空间的利用效率,也提高了编程人员的效率,很大程度上减少了因为没有释放空间而导致的内存泄露。

后续更高级的内容介绍:

1.垃圾收集器有几种

2.垃圾收集器底层原理剖析

3.垃圾收集器算法,优化

二、跨平台原理

JAVA跨平台原理的解释:

C语言的跨平台解释:

总结

JVM(Java Virtual Machine)就是一个虚拟的用于执行bytecode字节码的”虚拟计算机”。他也定义了指令集、寄存器集、结构栈、垃圾收集堆、内存区域。JVM负责将Java字节码解释运行,边解释边运行,这样,速度就会受到一定的影响。

不同的操作系统有不同的虚拟机。Java 虚拟机机制屏蔽了底层运行平台的差别,实现了“一次编译,随处运行”。 Java虚拟机是实现跨平台的核心机制。如图所示:

我们说的语言跨平台是编译后的文件跨平台,而不是源程序跨平台。

接下来我们再比较下两种方式的差异:

第一,C语言是编译执行的,编译器与平台相关,编译生成的可执行文件与平台相关;

第二,Java是解释执行的,编译为中间码的编译器与平台无关,编译生成的中间码也与平台无关(一次编译,到处运行),中间码再由解释器解释执行,解释器是与平台相关的,也就是不同的平台需要不同的解释器。

下一篇
举报
领券