草庐IT

动态代理入门必看

基本介绍代理就是让代理角色帮助真实角色完成一件事情。比如说,我叫我们朋友帮我完成博客,那么这个朋友就是代理,朋友不是我,但是和我完成同样的事,并且还可以对这件事加入他的行为逻辑。不论是什么代理方法,其根本目的就是为了拓展一个类的方法,也就是想要加入自己的行为逻辑。当然,我们可以直接修改类的方法,但是一旦类的方法多了起来,就会造成代码的冗余,而且极难进行维护。静态代理静态代理相当于是多写了一个代理类,在调用的时候调用的是代理类,在代理类中的处理还是原生的处理逻辑,不过在前后添加上需要添加的代码。其最根本的特征就是这个代理类需要程序员自己写出来。即在编译阶段就确定了代理对象是谁。实例说明:我们编写

JVM优化:JVM加载机制详解——类装载子系统

一、类加载子系统介绍1、类加载子系统负责从文件系统或是网络中加载.class文件,class文件在文件开头有特定的文件标识。2、把加载后的class类信息存放于方法区,除了类信息之外,方法区还会存放运行时常量池信息,可能还包括字符串字面量和数字常量(这部分常量信息是Class文件中常量池部分的内存映射);3、ClassLoader只负责class文件的加载,至于它是否可以运行,则由ExecutionEngine决定;4、如果调用构造器实例化对象,则该对象存放在堆区;二、类加载器ClassLoader角色1.classfile存在于本地硬盘上,可以理解为设计师画在纸上的模板,而最终这个模板在执行

JVM优化:实战OutOfMemoryError异常

一、Java堆溢出堆内存中主要存放对象、数组等,只要不断地创建这些对象,并且保证GCRoots到对象之间有可达路径来避免垃圾收集回收机制清除这些对象,当这些对象所占空间超过最大堆容量时,就会产生OutOfMemoryError的异常。堆内存异常示例如下:运行后会报异常,在堆栈信息中可以看到java.lang.OutOfMemoryError:Javaheapspace的信息,说明在堆内存空间产生内存溢出的异常。新产生的对象最初分配在新生代,新生代满后会进行一次MinorGC,如果MinorGC后空间不足会把该对象和新生代满足条件的对象放入老年代,老年代空间不足时会进行FullGC,之后如果空间

JVM中的垃圾回收机制

文章目录一、什么是垃圾回收二、为什么需要垃圾回收三、java中的四种引用类型四、垃圾识别机制1.引用计数算法2.可达性分析算法五、finalize()赋予对象重生流程图(finalize()存在时)六、四种垃圾回收算法标记清除算法标记整理算法复制算法分代收集算法MinorGC和FullGC区别一、什么是垃圾回收java相较于c、c++语言的优势之一是自带垃圾回收器,垃圾回收是指不定时去堆内存中清理不可达对象。不可达的对象并不会马上就会直接回收,垃圾收集器在一个Java程序中的执行是自动的,不能强制执行,程序员唯一能做的就是通过调用System.gc方法来建议执行垃圾收集器,但其是否可以执行,什

JVM调优篇:探索Java性能优化的必备种子面试题

JVM内存模型首先面试官会询问你在进行JVM调优之前,是否了解JVM内存模型的基础知识。这是一个重要的入门问题。JVM内存模型主要包括程序计数器、堆、本地方法栈、Java栈和方法区(1.7之后更改为元空间,并直接使用系统内存)。正常堆内存又分为年轻代和老年代。在Java虚拟机中,年轻代用于存放新创建的对象,而老年代则用于存放生命周期较长的对象。具体而言,根据默认设置,年轻代和老年代的比例通常为1:2。也就是说,年轻代占整个堆内存的1/3,而老年代占2/3。这样的比例设置可以更好地适应不同类型的对象的内存需求,提高垃圾回收效率,从而优化程序的性能。具体默认比例如下:JAVA类加载的全过程是怎样的

JVM调优:方法区,你学会了吗?

一、方法区的理解方法区(MethodArea)与Java堆一样,是各个线程共享的内存区域,它用于存储已被虚拟机加载的类型信息、常量、静态变量、即时编译器编译后的代码缓存等数据。《Java虚拟机规范》中明确说明:“尽管所有的方法区在逻辑上是属于堆的一部分,但些简单的实现可能不会选择去进行垃圾收集或者进行压缩”。对HotSpot而言,方法区还有一个别名叫做Non-Heap(非堆),的就是要和堆分开。元空间、永久代是方法区具体的落地实现。方法区看作是一块独立于Java堆的内存空间,它主要是用来存储所加载的类信息的创建对象各数据区域的声明:方法区的特点:方法区与堆一样是各个线程共享的内存区域方法区在J

一篇聊聊JVM优化:堆

一、Java堆概念1、简介对于Java应用程序来说,Java堆(JavaHeap)是虚拟机所管理的内存中最大的一块。Java堆是被所有线程共享的一块内存区域,在虚拟机启动时创建。此内存区域的唯一目的就是存放对象实例,Java世界里“几乎”所有的对象实例都在这里分配内存。“几乎”是指从实现角度来看,随着Java语言的发展,现在已经能看到些许迹象表明日后可能出现值类型的支持,即使只考虑现在,由于即时编译技术的进步,尤其是逃逸分析技术的日渐强大,栈上分配、标量替换优化手段已经导致一些微妙的变化悄然发生,所以说Java对象实例都分配在堆上也渐渐变得不是那么绝对了。2、堆的特点(1)是Java虚拟机所管

【五】线程安全VS线程不安全

1.Java内存模型的特征  Java内存模型是围绕着在并发过程中如何处理原子性、可见性和有序性这三个特征来建立。下面逐个看下哪些操作实现这三个特性:1.1原子性(Atomicity)  由Java内存模型来直接保证的原子性变量操作包括read、load、assign、use、store和write这六个,我们可以大致认为,基本数据类型的访问、读写都是具备原子性(例外就是long和double的非原子性协定),当然如果应用场景需要更大的范围来保证原子性,可以使用synchronized关键字,在synchronized块之间的操作也具备原子性。1.2可见性(Visibility)  所谓的可见

【五】线程安全VS线程不安全

1.Java内存模型的特征  Java内存模型是围绕着在并发过程中如何处理原子性、可见性和有序性这三个特征来建立。下面逐个看下哪些操作实现这三个特性:1.1原子性(Atomicity)  由Java内存模型来直接保证的原子性变量操作包括read、load、assign、use、store和write这六个,我们可以大致认为,基本数据类型的访问、读写都是具备原子性(例外就是long和double的非原子性协定),当然如果应用场景需要更大的范围来保证原子性,可以使用synchronized关键字,在synchronized块之间的操作也具备原子性。1.2可见性(Visibility)  所谓的可见

Java多线程wait()和notify()方法图解

多线程wait()和notify()方法详解文章目录多线程wait()和notify()方法详解前言一、线程间等待与唤醒机制二、等待方法wait()三、唤醒方法notify()四、关于wait和notify内部等待问题(重要)五、完整代码(仅供测试用)六、wait和sleep方法的区别(面试题):总结前言博主个人社区:开发与算法学习社区博主个人主页:KillingVibe的博客欢迎大家加入,一起交流学习~~一、线程间等待与唤醒机制wait()和notify()是Object类的方法,用于线程的等待与唤醒,必须搭配synchronized锁来使用。多线程并发的场景下,有时需要某些线程先执行,这些