当前位置: 首页 > news >正文

JVM快速入门(2)HotSpot和堆、新生区、永久区、堆内存调优、JProfiler工具分析OOM原因、GC(垃圾回收)、JVM经典面试笔试题整理

5.6 HotSpot和堆

5.6.1 Hotspot

三种JVM:

  • Sun公司,Hotspot
  • BEA,JRockit
  • IBM,J9 VM,号称是世界上最快的Java虚拟机

我们一般学习的是:HotSpot

5.6.2 堆

Heap,一个JVM只有一个堆内存,堆内存的大小是可以调节的。

类加载器读取了类文件后,一般会把什么东西放到堆中?类、方法、常量、变量,保存我们所有引用类型的真实对象。

堆内存中还要细分为三个区域:

  • 新生区(伊甸园区) Young/New
  • 养老区 old
  • 永久区 perm

5.7 新生区、永久区、堆内存调优

新生区:

  • 类:诞生、成长、甚至死亡

  • 伊甸园,所有的对象都是在伊甸园区new出来的

  • 幸存者区(0,1)

老年区:

经过研究,99%的对象都是临时对象!

永久区:

  • JDK1.6之前:永久代,常量池是在方法区;
  • JDK1.7:永久代,慢慢退化了,去永久代,常量池在堆中;
  • JDK1.8及之后:无永久代,常量池在元空间

在这里插入图片描述

5.8 JProfiler工具分析OOM原因

  • 内存快照工具:MAT、JProfiler;

  • MAT、JProfiler作用:

    • 分析Dump内存文件,快速定位内存泄露;
    • 获得堆中数据;
    • 获得大的对象
  • 查看内存情况:

    VM options: -Xms1024m -Xmx1024m -XX:+PrintGCDetails
    可以查看:
    Heap
    PSYoungGen total 305664K, used 15729K [0x00000000eab00000, 0x0000000100000000, 0x0000000100000000)
    eden space 262144K, 6% used [0x00000000eab00000,0x00000000eba5c420,0x00000000fab00000)
    from space 43520K, 0% used [0x00000000fd580000,0x00000000fd580000,0x0000000100000000)
    to space 43520K, 0% used [0x00000000fab00000,0x00000000fab00000,0x00000000fd580000)
    ParOldGen total 699392K, used 0K [0x00000000c0000000, 0x00000000eab00000, 0x00000000eab00000)
    object space 699392K, 0% used [0x00000000c0000000,0x00000000c0000000,0x00000000eab00000)
    Metaspace used 3144K, capacity 4496K, committed 4864K, reserved 1056768K
    class space used 342K, capacity 388K, committed 512K, reserved 1048576K

    
    
    
    

    -Xms8m -Xmx8m -XX:+HeapDumpOnOutOfMemoryError
    测试代码:
    package com.hzs.basic.jvm;
    import java.util.ArrayList;

    
    
    
    

    /**

    • @Author Cherist Huan
    • @Date 2021/7/9 22:55
    • @Version 1.0
      */
      // -Xms1024m -Xmx1024m -XX:+HeapDumpOnOutOfMemoryError
      public class TestJprofiler {

    byte[] array = new byte[110241024];

    public static void main(String[] args) {

    ArrayList list = new ArrayList<>();
    int count = 0;

    while(true){

     list.add(new TestJprofiler());count++;
    

    }
    }
    }

    输出:
    java.lang.OutOfMemoryError: Java heap space
    Dumping heap to java_pid8092.hprof …
    Heap dump file created [984453445 bytes in 0.824 secs]
    Exception in thread “main” java.lang.OutOfMemoryError: Java heap space
    at com.hzs.basic.jvm.TestJprofiler.(TestJprofiler.java:13)
    at com.hzs.basic.jvm.TestJprofiler.main(TestJprofiler.java:22)

    Process finished with exit code 1

    
    
    
    

在这里插入图片描述

在这里插入图片描述

在这里插入图片描述

5.9 GC(垃圾回收)

​ JVM在进行GC时,并不是对这三个区域统一回收,大部分时候,回收都是新生代:

  • 新生代
  • 幸存区(from,to)
  • 老年区

GC两种类型:轻GC(普通GC),重GC(全局GC、FullGC)

GC题目:

  • JVM的内存模型和分区,详细到每个分区放什么?

  • 堆里面的分区有哪些?说说它们的特点?

    • Eden,from,to,老年区
  • GC算法有哪些?怎么用的?

    • 标记清除法、标记压缩、复制算法、引用计数法
  • 轻GC和重GC分别在什么时候发生?

    • 轻GC(Minor GC)

    ​ 一般情况下,当新对象生成,并且在Eden申请空间失败时,就会触发Minor GC,对Eden区域进行GC,清除非存活对象,并且把尚且存活的对象移动到Survivor区。然后整理Survivor的两个区,这种方式的GC是对年轻代的Eden区进行,不会影响到老年代。因为大部分对象都是从Eden区开始的,同时Eden区不会分配的很大,所以Eden区的GC会频繁进行。因而,一般在这里需要使用速度快、I效率高的算法,使Eden区能尽快空闲出来。

    • 重GC (Full GC)

    对整个堆进行整理,包括年轻代、老年代、持久代。Full GC因为需要对整个堆进行回收,所以比Minor GC要慢,因而应该尽可能减少Full GC的次数。在对JVM调优的过程中,很大一部分工作就是对Full GC的调节。有如下的原因可能导致Full GC:

    (1)老年代被写满;

    (2)持久代被写满;

    (3)System.gc()被显示调用;

    (4)上一次GC之后Heap的各域分配策略动态变化

  • 为什么不是1块Survivor空间而是2块?

    分析:

    • 这里涉及到一个新生代和老年代的存活周期的问题,比如一个对象在新生代经历15次GC回收,就可以移到老年代了。
    • 问题来了,当我们第一次GC的时候,我们可以把Eden区的存活对象放到Survivor-1空间,但是第二次GC的时候,Survivor-1空间和Eden区的存活对象也需要再次用复制算法,放到Survivior-2空间上,而把刚刚的Survivor-1空间和Eden空间清除。第三次GC时,又把Survivor-2空间和Eden区的存活对象复制到Survivor-1空间,如此反复。
    • 所以,这里就需要2块Survivor空间来回倒腾。
  • 为什么Eden空间这么大而Survivor空间要分的少一点?

    分析:

    • 新创建的对象都是放在Eden空间,这是很频繁的,尤其是大量的局部变量产生的临时对象,这些对象绝大部分都应该马上被回收,能存活下来被转移到survivior空间一般不是很多。所以,设置较大的Eden空间和较小的Survivor空间是合理的,大大提高了内存的使用率,缓解了复制算法的缺点。

    • 8:1:1这种比例就挺好的,当然这个比例是可以调整的,包括上面的新生代和老年代的1:2的比例也是可以调整的。

    • 从Eden空间往Survivor空间转移的时候,如果出现Survivor空间不够了怎么办?直接放到老年代去。如果老年代Old区也被放满了,就是一次大GC即为Major GC。

    • 有的对象来回在Survivor-1区或者Survivor-2区待了比如15次,就被分配到老年代Old区;
    • 有的对象太大,超过了Eden区,直接被分配到Old区;
    • 有的存活对象,放不下Survivor区,也被分配到Old区。
5.9.1 GC-(标记-清除)(引用计数法)
  1. 流程

    主要分为“标记”和“清除”两个阶段:

    • (1)首先标记出所需要回收的对象(引用计数法和可达性分析,两次标记过程);
    • (2)在标记完成后统一回收所有被标记的对象。
  2. 缺点

    • (1)效率问题:标记和清除两个过程的效率不高;
    • (2)空间问题:标记清除后会产生大量不连续的内存碎片,导致以后在程序运行过程中需要分配较大对象时,无法找到足够的连续内存而不得不提前触发另一次垃圾收集工作。
5.9.2 GC-(复制)
  1. 流程

    可以解决效率问题,将可用的内存按容量划分为大小相等的两块

    • (1) 每次只使用其中的一块;
    • (2)当这一块用完了,就将还存活的对象复制到另一块上;
    • (3)然后再把已使用的内存空间清理掉。
  2. 优点

    • 每次对整个半区进行内存回收,避免了内存碎片问题;
    • 只需移动堆顶指针,按顺序分配内存即可,实现简单,运行高效。
  3. 缺点

    • 将内存缩小为原来的一般,代价高;
    • 当对象存活率高时,需要进行较多的复制操作,效率降低。
  4. 应用

    • 回收新生代,新生代中分为Eden空间和两块较小的Survivor空间,每次使用Eden和其中的一块Survivior。
    • 默认Eden:Survivor = 8:1 ,Survivor不够时,老年代内存分配担保。
5.9.3 GC-(标记-整理)
  1. 流程

    • (1)首先标记出所需要回收的对象;
    • (2)不直接对可回收对象进行清理,让所有存活的对象都向一段移动;
    • (3)直接清理掉端边界以外的内存。
  2. 优点

    改进了复制算法在对象存活率较高时带来的效率问题。

  3. 应用

    老年代收集(对象存活率较高)

5.9.4 GC-(分代收集)
  1. 思想

    根据对象存活周期的不同将内存划分为新生代和老年代,根据各自的特点采用合适的收集算法。

    • (1)新生代中,每次垃圾收集时都发现有大批对象死去,少量存活,用复制算法;
    • (2)老年代中,对象存活率高、没有额外空间进行分配担保,使用“标记-清理”或者“标记-整理”。
5.9.5 GC-总结
  • 内存效率:复制算法 > 标记清除算法 > 标记压缩(整理)算法 (时间复杂度)
  • 内存整齐度:复制算法 = 标记压缩(整理)算法 > 标记清除算法
  • 内存利用率:标记压缩(整理)算法 = 标记清除算法 > 复制算法

没有最优的GC算法,只有最合适的算法----> GC:分代收集算法。

年轻代:

  • 存活率低
  • 复制算法

老年代:

  • 区域大:存活率大
  • 标记清除 + 标记压缩混合实现

5.10 JVM经典面试笔试题整理

题目1:简述JVM的内存结构,并解释每个区域的作用

答案:

JVM的内存结构主要包括方法区、堆、栈(包括虚拟机栈和本地方法栈)和程序计数器。

  • 方法区:存储已被虚拟机加载的类信息、常量、静态变量、即时编译器编译后的代码等数据。
  • :是Java虚拟机所管理的内存中最大的一块,是所有线程共享的一块内存区域。它用于存放对象实例。
  • 虚拟机栈:每个方法被执行的时候都会创建一个栈帧用于存储局部变量表、操作数栈、动态链接、方法出口等信息。每一个方法从调用直至执行完成的过程,就对应着一个栈帧在虚拟机栈中入栈到出栈的过程。
  • 本地方法栈:与虚拟机栈所发挥的作用非常相似,其区别不过是虚拟机栈为虚拟机执行Java方法(也就是字节码)服务,而本地方法栈则为虚拟机使用到的Native方法服务。
  • 程序计数器:是一块较小的内存空间,可以看作是当前线程所执行的字节码的行号指示器。
题目2:什么是Java中的类加载器?它有什么作用?

答案:

Java中的类加载器(ClassLoader)负责加载类的二进制数据到JVM中,并转换成java.lang.Class类的实例。类加载器的主要作用是确保每个类的字节码被JVM加载时都是唯一的。Java提供了三种类加载器:启动类加载器(Bootstrap)、扩展类加载器(Extension)和系统类加载器(System)。此外,还可以自定义类加载器。类加载器采用双亲委派模型来加载类,这种模型可以保证Java核心类库的类型安全,防止应用程序随意替换核心类库中的类。

题目3:简述Java对象在JVM中的创建过程

答案:

Java对象在JVM中的创建过程大致如下:

  1. 类加载检查:当Java虚拟机遇到一条new指令时,首先将去检查这个指令的参数是否能在常量池的类符号表中找到一个与之对应的类符号引用,并且检查这个引用代表的类是否已被加载过、解析和初始化过。如果没有,那必须先执行相应的类加载过程。
  2. 分配内存:在类加载检查通过后,接下来虚拟机将为新生对象分配内存。对象所需内存的大小在类加载完成后便可完全确定,为对象分配空间的任务等同于把一块确定大小的内存从Java堆中划分出来。
  3. 初始化零值:内存分配完成后,虚拟机需要将分配到的内存空间都初始化为零值(不包括对象头),这一步保证了对象的实例字段在Java代码中可以不赋初值而直接使用,程序能访问到这些字段的数据类型所对应的零值。
  4. 设置对象头:初始化零值完成之后,虚拟机要对对象进行必要的设置,例如这个对象是哪个类的实例、如何才能找到类的元数据信息、对象的哈希码、对象的GC分代年龄等信息。这些信息存放在对象头中。
  5. 执行init方法:在上面工作都完成之后,从虚拟机的视角来看,一个新的对象已经产生了,但从Java程序的视角来看,对象创建才刚开始,<init>方法还没有执行,所有的字段值都为零。所以一般来说,执行new指令之后会接着执行<init>方法,把对象按照程序员的意愿进行初始化,这样一个真正可用的对象才算完全产生出来。
题目4:解释双亲委派模型及其作用?

答案:
双亲委派模型是Java类加载器的一个重要特性,其工作原理是:如果一个类加载器收到了类加载的请求,它首先不会自己去尝试加载这个类,而是把这个请求委派给父类加载器去完成,每一个层次的类加载器都是如此,因此所有的加载请求最终都应该传送到顶层的启动类加载器中。只有当父类加载器反馈自己无法完成这个加载请求(它的搜索范围中没有找到所需的类)时,子加载器才会尝试自己去加载。

双亲委派模型的好处在于:

  • 避免类的重复加载:当父类加载器已经加载了该类时,子类加载器就不会再加载。
  • 保证Java的核心类的安全:防止核心类的篡改,即使是用户自定义的类加载器,也无法加载一个核心类。
题目5:谈谈JVM中的垃圾回收机制?

答案1:
JVM中的垃圾回收机制是自动内存管理的重要部分,它主要负责自动回收不再使用的对象所占用的内存。

垃圾回收主要依赖于两个基本算法:引用计数算法和可达性分析算法。现代JVM主要使用可达性分析算法来判断对象是否可回收。通过一系列称为GC Roots的根对象作为起始点,从这些节点开始向下搜索,搜索所走过的路径称为引用链,当一个对象到GC Roots没有任何引用链相连时,则证明此对象是不可用的。

JVM提供了多种垃圾回收器,如Serial、Parallel、CMS、G1等,每种回收器都有其特点和适用场景。JVM会根据运行时的具体情况选择合适的垃圾回收器进行垃圾回收。

题目6:简述JVM中的栈内存溢出和堆内存溢出?

答案:

  • 栈内存溢出(StackOverflowError):通常是由于方法的递归调用没有正确的终止条件,导致无限递归调用,最终耗尽栈内存空间。此外,单个线程请求的栈深度大于虚拟机所允许的深度时,也会抛出StackOverflowError。

示例代码:

public class StackOverflowErrorDemo {  public static void main(String[] args) {  main(args); // 无限递归调用  }  
}
  • 堆内存溢出(OutOfMemoryError):通常是由于创建了大量的对象,并且GC无法回收足够的空间来满足新对象的分配需求。这可能是因为存在内存泄漏,或者堆的大小设置得太小,无法满足应用程序的需求。

示例代码(可能导致内存泄漏):

import java.util.ArrayList;  
import java.util.List;  public class OutOfMemoryErrorDemo {  static class Leaky {  public byte[] data = new byte[1024 * 1024]; // 1MB  }  public static void main(String[] args) {  List<Leaky> leakyList = new ArrayList<>();  while (true) {  leakyList.add(new Leaky()); // 不断创建新的对象并添加到列表中,但从未释放,导致内存泄漏  }
题目7:JVM内存区域划分及各自特点

题目描述
请简述JVM的内存区域划分,并解释每个区域的特点。

答案
JVM内存区域主要划分为以下几个部分:

  1. 方法区(Method Area):存储已被虚拟机加载的类信息、常量、静态变量、即时编译器编译后的代码等数据。
  2. 堆(Heap):所有线程共享的一块内存区域,用于存放对象实例。堆内存按照分代收集算法又可以分为新生代和老年代。
  3. 栈(Stack):每个线程都有一个私有的栈,用于存储局部变量表、操作数栈、动态链接、方法出口等信息。栈内存的生命周期与线程相同,随着线程的创建而创建,随着线程的销毁而销毁。
  4. 程序计数器(Program Counter Register):一块较小的内存空间,可以看作是当前线程所执行的字节码的行号指示器。字节码解释器工作时就是通过改变这个计数器的值来选取下一条需要执行的字节码指令。
题目8:双亲委派模型

题目描述
请解释JVM类加载器中的双亲委派模型,并给出其优点。

答案
双亲委派模型是JVM类加载器的一种加载机制,其工作原理如下:

  1. 当一个类加载器需要加载一个类时,它首先不会自己去尝试加载这个类,而是把这个请求委派给父类加载器去完成。
  2. 每一个层次的类加载器都是如此,因此所有的加载请求最终都应该传送到顶层的启动类加载器中。
  3. 只有当父类加载器无法完成这个加载请求(它的搜索范围中没有找到所需的类)时,子加载器才会尝试自己去加载。

双亲委派模型的优点主要有:

  1. 安全性:防止具有恶意的自定义加载器来篡改类的定义。
  2. 避免重复加载:确保一个类的全局唯一性,即一个类只会被加载一次。
题目9:从Java源码到执行的过程

题目描述
请简述从Java源码到执行的过程。

答案
从Java源码到执行的过程大致如下:

  1. 编写Java源码:使用文本编辑器编写Java源代码文件(.java)。
  2. 编译:使用Java编译器(javac)将.java文件编译成字节码文件(.class)。
  3. 类加载:JVM通过类加载器将.class文件加载到内存中,并生成对应的Class对象。
  4. 解释执行:JVM的解释器逐行解释执行字节码指令,或者通过即时编译器(JIT)将热点代码编译成机器码直接执行。
题目10:JVM中的垃圾回收算法

题目描述
请简述JVM中的垃圾回收算法及其特点。

答案
JVM中的垃圾回收算法主要有以下几种:

  1. 标记-清除(Mark-Sweep)算法:分为两个阶段,首先标记出所有需要回收的对象,然后统一回收被标记的对象。缺点是会产生内存碎片。
  2. 复制(Copying)算法:将可用内存按容量划分为大小相等的两块,每次只使用其中的一块。当这一块的内存用完了,就将还存活着的对象复制到另外一块上面,然后再把已使用过的内存空间一次清理掉。缺点是内存使用率不高。
  3. 标记-整理(Mark-Compact)算法:标记过程仍然与“标记-清除”算法一样,但后续步骤不是直接对可回收对象进行清理,而是让所有存活的对象都向一端移动,然后直接清理掉端边界以外的内存。
  4. 分代收集(Generational Collection)算法:根据对象存活

相关文章:

JVM快速入门(2)HotSpot和堆、新生区、永久区、堆内存调优、JProfiler工具分析OOM原因、GC(垃圾回收)、JVM经典面试笔试题整理

5.6 HotSpot和堆 5.6.1 Hotspot 三种JVM&#xff1a; Sun公司&#xff0c;HotspotBEA&#xff0c;JRockitIBM&#xff0c;J9 VM&#xff0c;号称是世界上最快的Java虚拟机 我们一般学习的是&#xff1a;HotSpot 5.6.2 堆 Heap&#xff0c;一个JVM只有一个堆内存&#xff0c…...

我的风采——android studio

目录 实现“我的风采”页面要求理论代码生成apk文件 实现“我的风采”页面 要求 要求利用’java框架的边框布局实现“找的风采 ”页而&#xff0c;其中中间为你的生活照&#xff0c;左右和下面为按钮&#xff0c;上面为标签 理论 Java GUI编程是Java程序设计的重要组成部分…...

BMS设计中的短路保护和MOSFET选型(上)

电池管理系统&#xff08;BMS&#xff09;是一种能够对电池进行监控和管理的电子装备&#xff0c;是电池与用户之间的纽带。通过对电压、电流、温度以及SOC等数据采集&#xff0c;计算进而控制电池的充放电过程&#xff0c;主要就是为了能够提高电池的利用率&#xff0c;防止电…...

用go实现一个任务调度类 (泛型)

用go实现一个任务调度类 &#xff08;泛型&#xff09; 源码地址&#xff1a; https://github.com/robinfoxnan/BirdTalkServer/blob/main/server/core/workmanager.go 1.概述 实现了一个简单的任务管理系统&#xff0c;允许用户定义任务和工作者&#xff0c;并将任务分配给…...

ansible 管理工具以及常用模块

一、前期准备 1、安装 yum install ansible 如果yum源没有ansible&#xff0c;需要提前配置yum源&#xff1a; mv /etc/yum.repos.d/epel.repo /etc/yum.repos.d/epel.repo.backup mv /etc/yum.repos.d/epel-testing.repo /etc/yum.repos.d/epel-testing.repo.backup wget -O…...

javaSSM公司招聘管理系统IDEA开发mysql数据库web结构计算机java编程maven项目

一、源码特点 IDEA开发SSM公司招聘管理系统是一套完善的完整企业内部系统&#xff0c;结合SSM框架和bootstrap完成本系统&#xff0c;对理解JSP java编程开发语言有帮助系统采用SSM框架&#xff08;MVC模式开发&#xff09;MAVEN方式加 载&#xff0c;系统具有完整的源代码和…...

蓝桥杯day11刷题日记

P8615 [蓝桥杯 2014 国 C] 拼接平方数 思路&#xff1a;先把数据范围内的平方数打上标记&#xff0c;然后就是遍历这个区间&#xff0c;转成字符串&#xff08;好拆数据&#xff09;&#xff0c;用substr拆开数据&#xff0c;再强转成整数类型&#xff0c;最后查看拆开的数据是…...

IDEA, Pycharm, Goland控制台乱码

IDEA, Pycharm, Goland控制台乱码 问题描述: 控制台出现&#xfffd;&#xfffd;&#xfffd;&#xfffd;等乱码 复现频率: 总是 解决方案: 以IDEA为例 添加 -Dfile.encodingUTF-8位置 idea64.exe.vmoptions 在安装idea的bin目录idea.vmoptions idea客户端 示意图...

JavaScript单元测试jasmine学习(一)

介绍&#xff1a; jasmine是用于测试JavaScript的一种测试框架,BDD(Behavior Driven Development)行为驱动开发。不依赖于任何其他JavaScript框架&#xff0c;也不需要DOM 准备工作&#xff1a; 1. 首先添加jasmine到自己的项目中 npm install --save-dev jasmine 2. 在项目…...

108、3D Gaussian Splatting for Real-Time Radiance Field Rendering

简介 官网 更少训练时间的同时实现最先进的视觉质量&#xff0c;能在1080p分辨率下实现高质量的实时(≥30 fps)新视图合成 NeRF使用隐式场景表示&#xff0c;体素&#xff0c;点云等属于显示建模方法&#xff0c;3DGS就是显示辐射场。它用3D高斯作为灵活高效的表示方法&…...

PHP之CURL和Socket

文章目录 一、CURL1.基本流程&#xff08;1&#xff09;初始化&#xff08;2&#xff09;向服务器发送请求&#xff08;3&#xff09;向服务器发送请求&#xff08;4&#xff09;关闭curl 2.CURLOPT参数记得写一个文件curl上传的例子记得写一个json上传的例子3.CURL批处理 二、…...

【Web】NKCTF 2024 个人wp(部分)

目录 my first cms 全世界最简单的CTF attack_tacooooo 属实太菜了&#xff0c;3/4 my first cms 一眼搜版本2.2.19 CVE -CVE-2024-27622 GitHub - capture0x/CMSMadeSimple 访问/admin/login.php 爆出弱口令&#xff0c;后台登录 admin Admin123 Extensions > User D…...

QT常见布局器使用

布局简介 为什么要布局&#xff1f;通过布局拖动不影响鼠标拖动窗口的效果等优点.QT设计器布局比较固定&#xff0c;不方便后期修改和维护&#xff1b;在Qt里面布局分为四个大类 &#xff1a; 盒子布局&#xff1a;QBoxLayout 网格布局&#xff1a;QGridLayout 表单布局&am…...

政安晨:【深度学习部署】—— TensorFlow Extended(TFX)介绍

政安晨的个人主页&#xff1a;政安晨 欢迎 &#x1f44d;点赞✍评论⭐收藏 收录专栏: TensorFlow与Keras实战演绎机器学习 希望政安晨的博客能够对您有所裨益&#xff0c;如有不足之处&#xff0c;欢迎在评论区提出指正&#xff01; 前言 TensorFlow Extended&#xff08;TFX&a…...

宝石与石头

宝石与石头 链接:https://leetcode.cn/problems/jewels-and-stones/description/ 给你⼀个字符串 jewels 代表石头中宝石的类型&#xff0c;另有⼀个字符串 stones 代表你拥有的石头。 stones 中每个字符代表了⼀种你拥有的石头的类型&#xff0c;你想知道你拥有的石头中有多…...

【Vue3之computed属性(四)】

文章目录 前言一、computed属性有缓存二、使用方法三、修改全名 前言 理解computed属性&#xff0c;实现输入姓和名得出全名并双向绑定&#xff0c;区分单向绑定和双向绑定。测试computed属性和方法的区别 一、computed属性有缓存 先引入computed&#xff0c;写箭头函数定义并…...

生产力工具|安装更新R软件(R、studio)

内容介绍&#xff1a; 安装R软件&#xff1a; 下载 R X64 3.5.1: 访问官方R网站 https://cran.r-project.org/。选择适合Windows版本的安装包。将安装包下载到您的计算机。 本地安装: 运行下载的“R-3.5.1-win.exe”文件。按照安装向导&#xff0c;选择安装路径&#xff0c;取消…...

ffmpeg实现媒体流解码

本期主要讲解怎么将MP4媒体流的视频解码为yuv,音频解码为pcm数据;在此之前我们要先了解解复用和复用的概念; 解复用:像mp4是由音频和视频组成的(其他内容流除外);将MP4的流拆分成视频流(h264或h265等)和音频流(AAC或mp3等); 复用:就是将音频和视频打包成MP4或者fl…...

面试题 之 react

1.说说对react的理解 1️⃣是什么 React是用于构建用户界面的 JavaScript 库,遵循组件设计模式、声明式编程范式和函数式编程概念&#xff0c;更高效使用虚拟 DOM 来有效地操作 DOM &#xff0c;遵循从高阶组件到低阶组件的单向数据流。 react 类组件使用一个名为 render() 的方…...

k8s笔记27--快速了解 k8s pod和cgroup的关系

k8s笔记27--快速了解 k8s pod和 cgroup 的关系 介绍pod & cgroup注意事项说明 介绍 随着云计算、云原生技术的成熟和广泛应用&#xff0c;K8S已经成为容器编排的事实标准&#xff0c;学习了解容器、K8S技术对于新时代的IT从业者显得极其重要了。 之前在文章 docker笔记13–…...

[2025CVPR]DeepVideo-R1:基于难度感知回归GRPO的视频强化微调框架详解

突破视频大语言模型推理瓶颈,在多个视频基准上实现SOTA性能 一、核心问题与创新亮点 1.1 GRPO在视频任务中的两大挑战 ​安全措施依赖问题​ GRPO使用min和clip函数限制策略更新幅度,导致: 梯度抑制:当新旧策略差异过大时梯度消失收敛困难:策略无法充分优化# 传统GRPO的梯…...

Vue3 + Element Plus + TypeScript中el-transfer穿梭框组件使用详解及示例

使用详解 Element Plus 的 el-transfer 组件是一个强大的穿梭框组件&#xff0c;常用于在两个集合之间进行数据转移&#xff0c;如权限分配、数据选择等场景。下面我将详细介绍其用法并提供一个完整示例。 核心特性与用法 基本属性 v-model&#xff1a;绑定右侧列表的值&…...

为什么需要建设工程项目管理?工程项目管理有哪些亮点功能?

在建筑行业&#xff0c;项目管理的重要性不言而喻。随着工程规模的扩大、技术复杂度的提升&#xff0c;传统的管理模式已经难以满足现代工程的需求。过去&#xff0c;许多企业依赖手工记录、口头沟通和分散的信息管理&#xff0c;导致效率低下、成本失控、风险频发。例如&#…...

鸿蒙中用HarmonyOS SDK应用服务 HarmonyOS5开发一个生活电费的缴纳和查询小程序

一、项目初始化与配置 1. 创建项目 ohpm init harmony/utility-payment-app 2. 配置权限 // module.json5 {"requestPermissions": [{"name": "ohos.permission.INTERNET"},{"name": "ohos.permission.GET_NETWORK_INFO"…...

OpenPrompt 和直接对提示词的嵌入向量进行训练有什么区别

OpenPrompt 和直接对提示词的嵌入向量进行训练有什么区别 直接训练提示词嵌入向量的核心区别 您提到的代码: prompt_embedding = initial_embedding.clone().requires_grad_(True) optimizer = torch.optim.Adam([prompt_embedding...

SpringTask-03.入门案例

一.入门案例 启动类&#xff1a; package com.sky;import lombok.extern.slf4j.Slf4j; import org.springframework.boot.SpringApplication; import org.springframework.boot.autoconfigure.SpringBootApplication; import org.springframework.cache.annotation.EnableCach…...

在Ubuntu24上采用Wine打开SourceInsight

1. 安装wine sudo apt install wine 2. 安装32位库支持,SourceInsight是32位程序 sudo dpkg --add-architecture i386 sudo apt update sudo apt install wine32:i386 3. 验证安装 wine --version 4. 安装必要的字体和库(解决显示问题) sudo apt install fonts-wqy…...

Java + Spring Boot + Mybatis 实现批量插入

在 Java 中使用 Spring Boot 和 MyBatis 实现批量插入可以通过以下步骤完成。这里提供两种常用方法&#xff1a;使用 MyBatis 的 <foreach> 标签和批处理模式&#xff08;ExecutorType.BATCH&#xff09;。 方法一&#xff1a;使用 XML 的 <foreach> 标签&#xff…...

A2A JS SDK 完整教程:快速入门指南

目录 什么是 A2A JS SDK?A2A JS 安装与设置A2A JS 核心概念创建你的第一个 A2A JS 代理A2A JS 服务端开发A2A JS 客户端使用A2A JS 高级特性A2A JS 最佳实践A2A JS 故障排除 什么是 A2A JS SDK? A2A JS SDK 是一个专为 JavaScript/TypeScript 开发者设计的强大库&#xff…...

LabVIEW双光子成像系统技术

双光子成像技术的核心特性 双光子成像通过双低能量光子协同激发机制&#xff0c;展现出显著的技术优势&#xff1a; 深层组织穿透能力&#xff1a;适用于活体组织深度成像 高分辨率观测性能&#xff1a;满足微观结构的精细研究需求 低光毒性特点&#xff1a;减少对样本的损伤…...