JVM(一) Java类的加载机制

1、类的加载

      定义:将类的.class文件中二进制数据读入到内存中,将其放在运行时数据区的方法区内,然后在堆区创建一个

                 java.lang.Class对象, 用来封装在方法区内的数据结构;

                类加载最终产品为位于堆区中class对象,class对象封装了类在方法区中的数据结构,并向Java程序员提供

                了访问方法区内数据结构的接口;

                                         

      注意:类加载器并不是要等到某个类被 "首次主动使用" 时再加载它,JVM规范允许类加载器预先加载即将要被使用的类,

                 如果预先加载过程中存在 .class文件缺失或存在错误,类加载器必须在程序首次使用该类时才报告错误(LinkageError),

                 如果这个类一直没有被程序主动使用,那么类加载器就不会报错;


2、类的生命周期

                        

     加载:通过一个类的全限定名来获取其定义的二进制字节流;

                将这个字节流所代表的静态存储结构转化为方法区的运行时数据结构;

                 在Java堆中生成一个代表这个类的java.lang.Class对象,作为对方法区中数据的访问入口;

     验证:确保被加载的类的正确性,包含文件格式验证、元数据验证、字节码验证、符号引用验证;

     准备:为类的静态变量分配内存,并将其初始化为默认值;

                (1)准备阶段进行内存分配仅包括类变量(static);

                (2)所设置的初始值通常情况下是数据类型默认的零值(如0、0L、null、false等);

                 public static int value = 3;

                 value变量在准备阶段过后的初始值是0,而不是3;把value赋值为3的动作在初始化阶段才会执行;

                 (3)如果类变量同时被static 、final修饰,那么在准备阶段变量就会被初始化成其显式指定的值;

                 public static final int value = 3 ;

                 value变量在准备阶段过后的初始值是3;

     解析:把类中的符号引用转换为直接引用;

     初始化:为类的静态变量赋予正确的初始值;


3、类加载器   

      几种类加载器层次图

                          

     JVM角度分析类加载器

      启动类加载器,JVM自身一部分;

      其他类加载器,独立于JVM,全部继承自抽象类java.lang.ClassLoader,这些类加载器需要由启动类加载器加载到

                               内存中之后才能加载其他的类;

     Java开发人员角度分析类加载器:

      启动类加载器负责加载存放在JDK\jre\lib下 或 被Xbootclasspath参数指定的路径中,并且能被jvm识别类库;

                               启动类加载器是无法被java程序直接引用的;

      扩展类加载器负责加载JDK\jre\lib\ext下 或 java.ext.dirs系统变量指定的路径中的所有类库 ;

                                开发者可以直接使用扩展类加载器;

      应用程序类加载器负责加载用户类路径所指定的类,开发者可以直接使用该类加载器;


4、jvm类加载机制

      全盘负责:当一个类加载器负责加载某个class时,该class所依赖的和引用的其他class也将由该加载器负责加载;

      父类委托:先让父类加载器试图加载该类,如果父类加载器无法加载该类时才尝试从自己的类路径加载中加载该类;

      缓存机制:缓存机制保证所有被类加载器加载过class都会被缓存;当程序中需要使用某个class时,类加载器先从缓存

                         区寻找该class,如果缓存区不存在,类加载器就会去读取该类对应的二进制数据,并将其转换成class对象,

                         存入缓存区;所以,修改class文件后,必须重启JVM,修改后的程序才会生效;


5、类加载方式

     三种方式: 命令行启动应用程序时由JVM初始化加载;

                        通过Class.forName()方法动态加载;

                        通过ClassLoader.loadClass()方法动态加载;

     例子

      

      

     


6、双亲委派模型

 定义:如果一个类加载器接收到了类加载的请求,它首先不会尝试自己去加载这个类,会委托给其父类加载器,依次向上,

            直到到达最顶级的启动类加载器(BootstrapClassLoader);如果当父类加载器无法加载该类时,子类加载器才会尝试

            去加载该类;

 举例:(1) 当AppClassLoader加载一个class时,它不会尝试去加载此Class,而是将加载请求委托给父类加载 

                 器ExtClassLoader;

            (2)当ExtClassLoader加载一个class时,它不会尝试去加载此Class,而是将加载请求委托给父类加载

                器BootStrapClassLoader;

            (3)当BootStrapClassLoader加载失败(在JDK/jre/lib里未查找到该class),会使用ExtClassLoader去加载;

            (4)当ExtClassLoader加载失败,会使用AppClassLoader去加载,如果AppClassLoader加载失败,则会

                报出异常ClassNotFoundException;


7、参考

http://www.ityouknow.com/jvm/2017/08/19/class-loading-principle.html

              

                                           

 

               

 

      

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
目标检测(Object Detection)是计算机视觉领域的一个核心问题,其主要任务是找出图像中所有感兴趣的目标(物体),并确定它们的别和位置。以下是对目标检测的详细阐述: 一、基本概念 目标检测的任务是解决“在哪里?是什么?”的问题,即定位出图像中目标的位置并识别出目标的别。由于各物体具有不同的外观、形状和姿态,加上成像时光照、遮挡等因素的干扰,目标检测一直是计算机视觉领域最具挑战性的任务之一。 二、核心问题 目标检测涉及以下几个核心问题: 分问题:判断图像中的目标属于哪个别。 定位问题:确定目标在图像中的具体位置。 大小问题:目标可能具有不同的大小。 形状问题:目标可能具有不同的形状。 三、算法分 基于深度学习的目标检测算法主要分为两大: Two-stage算法:先进行区域生成(Region Proposal),生成有可能包含待检物体的预选框(Region Proposal),再通过卷积神经网络进行样本分。常见的Two-stage算法包括R-CNN、Fast R-CNN、Faster R-CNN等。 One-stage算法:不用生成区域提议,直接在网络中提取特征来预测物体分和位置。常见的One-stage算法包括YOLO系列(YOLOv1、YOLOv2、YOLOv3、YOLOv4、YOLOv5等)、SSD和RetinaNet等。 四、算法原理 以YOLO系列为例,YOLO将目标检测视为回归问题,将输入图像一次性划分为多个区域,直接在输出层预测边界框和别概率。YOLO采用卷积网络来提取特征,使用全连接层来得到预测值。其网络结构通常包含多个卷积层和全连接层,通过卷积层提取图像特征,通过全连接层输出预测结果。 五、应用领域 目标检测技术已经广泛应用于各个领域,为人们的生活带来了极大的便利。以下是一些主要的应用领域: 安全监控:在商场、银行
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值