jvm学习:类的加载、连接、初始化、常量
类在jvm中有这几个过程类的加载、连接、初始化、使用、卸载
类的加载
类的加载是将class文件中的二进制数据加载到内存中,将其放在运行时的数据区:方法区内,然后在内存中创建一个
java.lang.Class对象用来封装类在方法区内的数据结构。规范没有规定Class对象放在哪里,hotspot虚拟机将其放在了方法区中。
加载.class文件的方式
从本地系统中加载
从网络下载.class文件
从zip jar文件中加载
将java原文件动态的编译为.class文件,比如jsp
类的使用
java的类主动使用,才会执行初始化
主动使用
创建类的实例
访问某个类或者接口的非final变量、对改静态变量的赋值
调用类的静态方法
反射
初始化一个类的子类
表明为启动类比如main方法
java1.7动态语言支持
例子
运行下面的例子可以先打印str1,然后打印str2。
package com.javalearn.jvm.classloader;
import lombok.extern.slf4j.Slf4j;
/**
* 对于静态字段来说,只有直接使用定义了该字段的类才会被初始化
* 当一个类加载要求父类加载完毕
*/
@Slf4j
public class MyTest {
public static void main(String[] args) {
log.info(MyChild1.str2);
}
}
@Slf4j
class MyParent1 {
public static String str1 = "hello";
static {
log.info("my parent static block");
}
}
@Slf4j
class MyChild1 extends MyParent1 {
public static String str2 ="hello child2";
static {
log.info("my child1 static block");
}
}
结果
22:47:54.901 [main] INFO com.javalearn.jvm.classloader.MyParent1 - my parent static block
22:47:54.905 [main] INFO com.javalearn.jvm.classloader.MyChild1 - my child1 static block
22:47:54.905 [main] INFO com.javalearn.jvm.classloader.MyTest - hello child2
使用反射是主动使用,会初始化类,但ClassLoader不是主动使用
package com.learn.java.javabase.jvm.classloader;
public class ClassLoaderTest012 {
public static void main(String[] args) {
ClassLoader classLoader=ClassLoader.getSystemClassLoader();
Class<?> c1;
try {
c1 = classLoader.loadClass("com.learn.java.javabase.jvm.classloader.Test012");
System.out.println(c1);
System.out.println("--------");
c1=Class.forName("com.learn.java.javabase.jvm.classloader.Test012");
System.out.println(c1);
System.out.println("--------");
} catch (ClassNotFoundException e) {
e.printStackTrace();
}
System.out.println("--------");
}
}
class Test012{
static {
System.out.println("test012");
}
}
运行结果
class com.learn.java.javabase.jvm.classloader.Test012
--------
test012
class com.learn.java.javabase.jvm.classloader.Test012
--------
--------
初始化
类初始化的时候,会首先初始化它的父类,比如Object类
接口初始化的时候,不会初始化它的父接口
初始化是按照上下文的顺序初始化
package com.learn.java.javabase.jvm.classloader;
import java.util.Random;
public class ClassLoaderInterfaceTest {
public static void main(String[] args) {
// Paraent01 paraent01 =new Paraent01();
// Paraent01 paraent02 =new Paraent01();
// Child01 child01 =new Child01();
//System.out.println(Paraent01.paraent01);
System.out.println(Child01.childInt);
}
}
class Paraent01 {
//常量会在编译期间放到调用类的常量池中
public static final int paraent01=10;
//public static int paraent01=10;
//静态代码块随着类的加载只会执行一次
static {
System.out.println("paraent01");
}
}
class Child01 extends Paraent01 {
public static int childInt =5;
static {
System.out.println("child01");
}
}
结果
paraent01
child01
5
常量
常量会在编译期加载使用类的常量池中
下面的例子Child01的常量在test类使用的时候,已经放入到常量池。说明
final变量的调用不是主动使用,并不会导致父类的初始化
package com.learn.java.javabase.jvm.classloader;
import java.util.Random;
public class ClassLoaderInterfaceTest {
public static void main(String[] args) {
// Paraent01 paraent01 =new Paraent01();
// Paraent01 paraent02 =new Paraent01();
// Child01 child01 =new Child01();
//System.out.println(Paraent01.paraent01);
System.out.println(Child01.childInt);
}
}
class Paraent01 {
//常量会在编译期间放到调用类的常量池中
public static final int paraent01=10;
//public static int paraent01=10;
//静态代码块随着类的加载只会执行一次
static {
System.out.println("paraent01");
}
}
class Child01 extends Paraent01 {
public static final int childInt =5;
static {
System.out.println("child01");
}
}
输出结果
5
jvm学习:类的加载、连接、初始化、常量的更多相关文章
- 深入java虚拟机学习 -- 类的加载机制(续)
昨晚写 深入java虚拟机学习 -- 类的加载机制 都到1点半了,由于第二天还要工作,没有将上篇文章中的demo讲解写出来,今天抽时间补上昨晚的例子讲解. 这里我先把昨天的两份代码贴过来,重新看下: ...
- Java 类的加载与初始化
本文结构: 1.先看几道题 2.类的加载于初始化 (1)类的加载 (2)类的初始化 (a)会发生类的初始化的情况 (b)不会发生类的初始化的情况 首先看几道题. 解析可在看完讲解后再看 Demo1 p ...
- java类的加载以及初始化顺序
类的加载和初始化的了解对于我们对编程的理解有很大帮助,最近在看类的记载方面的问题.从网上查阅了若干文章,现总结如下: 我们通过一段代码来了解类加载和初始化的顺序: package com.classl ...
- JVM 1.类的加载、连接、初始化
Java类的加载是由类加载器来完成的,过程如下: 首先,加载是把硬盘.网络.数据库等的class文件中的二进制数据加载到内存的过程,然后会在Java虚拟机的运行时数据区的堆区创建一个Class对象,用 ...
- 深入java虚拟机学习 -- 类的加载机制
当看到"类的加载机制",肯定很多人都在想我平时也不接触啊,工作中无非就是写代码,不会了可以百度,至于类,jvm是怎么加载的我一点也不需要关心.在我刚开始工作的时候也觉得这些底层的内 ...
- jvm(1)类的加载(二)(自定义类加载器)
[深入Java虚拟机]之四:类加载机制 1,从Java虚拟机的角度,只存在两种不同的类加载器: 1,启动类加载器:它使用C++实现(这里仅限于Hotspot,也就是JDK1.5之后默认的虚拟机,有其他 ...
- JVM:java类的加载机制
原文连接:https://www.cnblogs.com/ityouknow/p/5603287.html 类加载机制的奥妙. 1.什么是类的加载 类的加载指的是将类的.class文件中的二进制数据读 ...
- Java类的加载 链接 初始化
原文地址 Java类的加载.链接和初始化.Java字节代码的表现形式是字节数组(byte[]),而Java类在JVM中的表现形式是java.lang.Class类的对象.一个Java类从字节代码到能够 ...
- 深入java虚拟机学习 -- 类的加载机制(三)
类的初始化时机 在上篇文章中讲到了类的六种主动使用方式,反射是其中的一种(Class.forName("com.jack.test")),这里需要注意一点:当调用ClasLoade ...
- jvm(1)类的加载(三)(线程上下文加载器)
简介: 类加载器从 JDK 1.0 就出现了,最初是为了满足 Java Applet 的需要而开发出来的. Java Applet 需要从远程下载 Java 类文件到浏览器中并执行. 现在类加载器在 ...
随机推荐
- Java开发中模拟接口工具moco的使用
场景 在开发中需要依赖一些接口,比如需要请求一个返回Json数据的接口,但是返回Json数据的接口要么是没搭建,要么是交互比较复杂. 此时,就可以使用moco来模拟接口返回接口数据,以便开发和测试工作 ...
- JavaScript - what is "this"? this是什么?
https://fangyinghang.com/this-in-js/ Core func(p1, p2) // 等同于 func.call(undefined, p1, p2) this 就是ca ...
- 如何让后加载的元素被一开始就有的css样式渲染成功(强制提升css优先级)
今天在做搜索框中的提示语下拉的时候,提示框把搜索框的底部的border遮住,导致看起来不是很美观: 因为下方的提示框是用js后加载的它的样式也是随着js一起加载的,而这个js和它的css我们是不能改动 ...
- zookeeper 源码(一) 选举和同步数据
前言 在开始阅读代码前我们先来了解一下zk 的大致结构,具体大概要实现的核心功能有那些,心中有个大概的框架阅读代码时再深入其中的细节,就会非常好懂,本人觉得这是一个阅读源码的好方法,可以最快地切入到源 ...
- excel截取第一个空格前的字符
excel 替换 空格字符后面的所有字符 =TRIM(REPLACE(A1,FIND(" ",A1),999,)) =TRIM(REPLACE(A1,1,FIND(" & ...
- java 工程idea 添加依赖几种方式:
1.add jar and dependecy derictory: 2.add Libary: 点击new library 选取java: 选择libs文件夹作为library: 选择 maven ...
- python爬取course课程的信息
目录 1.大模块页面 2.每个大模块中小模块的简单信息 3.每个小课程的详细信息 4.爬取所有评论 @ 这几天爬取了course动态网页的课程信息,有关数据分析,机器学习,还有概率论和数理统计课程 ...
- Node.js 服务端处理图片
Node 服务端处理图片 服务端进行图片处理是很常见的需求,但是Node在这一块相对来说比较薄弱.找了几个比较常见的模块来解决问题. gm GraphicsMagick for node 使用Open ...
- 校准产品质量,把控出海航向,腾讯WeTest《2019中国移动游戏质量白皮书》正式开放预约
作者:wetest小编 商业转载请联系腾讯WeTest获得授权,非商业转载请注明出处. 原文链接:https://wetest.qq.com/lab/view/483.html 每当步入一个新的年份, ...
- 【docker问题】Client.Timeout exceeded while awaiting headers
在进行docker pull 拉取镜像时,出现过下面的错误: net/http: request canceled while waiting for connection (Client.Timeo ...