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

news/2024/5/10 11:49:25/文章来源:https://blog.csdn.net/donghuandong/article/details/136995793

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)算法:根据对象存活

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.luyixian.cn/news_show_1027559.aspx

如若内容造成侵权/违法违规/事实不符,请联系dt猫网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

【I.MX6ULL移植】Ubuntu-base根文件系统移植

1.下载Ubuntu16.04根文件系统 http://cdimage.ubuntu.com/ 1 2 3 4 5 2.解压ubuntu base 根文件系统 为了存放 ubuntu base 根文件系统&#xff0c;先在 PC 的 Ubuntu 系统中的 nfs 目录下创建一个名为 ubuntu_rootfs 的目录&#xff0c;命令如下&#xff1a; 【注意&…

【IP 组播】PIM-SM

目录 原理概述 实验目的 实验内容 实验拓扑 1.基本配置 2.配置IGP 3.配置PIM-SM 4.用户端DR与组播源端DR 5.从RPT切换到SPT 6.配置PIM-Silent接口 原理概述 PIM-SM 是一种基于Group-Shared Tree 的组播路由协议&#xff0c;与 PIM-DM 不同&#xff0c;它适合于组播组成…

【word技巧】word复制整页格式不变,如何做到?

Word文档内容中的某页需要复制粘贴到其他word文档&#xff0c;如何做才能保持整页格式不变&#xff1f;今天分享几个方法&#xff0c;帮助大家解决word复制整页格式不变。 方法一&#xff1a; 最简单的方法就是&#xff0c;找到需要复制的页面&#xff0c;从第一行使用光标选…

鸿蒙TypeScript开发入门学习第3天:【TS基础类型】

1、TypeScript 基础类型 TypeScript 包含的数据类型如下表: 注意&#xff1a; TypeScript 和 JavaScript 没有整数类型。 2、Any 类型 任意值是 TypeScript 针对编程时类型不明确的变量使用的一种数据类型&#xff0c;它常用于以下三种情况。 1、变量的值会动态改变时&…

连续信号离散信号的功率谱密度--用MATLAB求功率谱密度

连续信号&离散信号的功率谱密度--用MATLAB求功率谱密度 目录 前言 一、能量及功率定义 1、连续信号 2、离散信号 二、功率谱密度计算公式 三、MATLAB仿真 1、源代码 2、仿真结果分析 总结 前言 一直对数字信号处理中的功率谱密度计算有点好奇&#xff0c;虽然MATLAB有提供现…

提升K8S故障排除效率:详解Pod内抓包的高效策略!

在Kubernetes环境中&#xff0c;故障排除是管理者日常工作中不可或缺的一部分。随着容器化应用的广泛采用&#xff0c;需要一种高效的方法来诊断和解决Pod内部的问题。本文将重点介绍如何利用抓包技术提升Kubernetes环境中Pod内部故障排除的效率。 为什么需要Pod内抓包 在Kube…

零售商品计划新篇章:智能管理系统的挑战与机遇

在零售企业管理中&#xff0c;商品计划管理在零售企业运营中占据核心地位。面对日益激烈的市场竞争和消费者需求的多样化&#xff0c;零售企业在商品计划管理方面面临着诸多挑战和需求。以下针对这些挑战和需求的分析&#xff0c;以及对一套智能商品计划管理系统应具备的功能和…

高效运维|AIRIOT智慧电力运维解决方案

可再生能源的引入带来了能源生产的去中心化和分散化趋势&#xff0c;同时也带来了能源输出的波动性和不确定性。电力运维因此需要更加灵活、智能的解决方案&#xff0c;以适应可再生能源的集成&#xff0c;确保电力系统的稳定运行&#xff0c;传统的电力运维管理方式往往存在如…

Vite 为什么比 Webpack 快?

目录 1. Webpack 的构建原理 2. Script 的模块化&#xff08;主流浏览器对 ES Modules 的支持&#xff09; 3. Webpack vs Vite 开发模式的差异 对 ES Modules 的支持 底层语言的差异 热更新的处理 1. Webpack 的构建原理 前端之所以需要类似于 Webpack 这样的构建工具&…

【教学类-40-09】A4骰子纸模制作9.0(3.47CM嵌套骰子 一条8格便于对折,表格相连 一页3个 油墨打印A4铅画纸)

作品展示 背景需求&#xff1a; 骰子调整到第8版&#xff0c;把骰子图案作成一长条&#xff0c;便于切割裁剪。 【教学类-40-08】A4骰子纸模制作8.0&#xff08;2.97CM嵌套骰子表格相连 一页7个 油墨打印A4铅画纸&#xff09;-CSDN博客文章浏览阅读929次&#xff0c;点赞20次…

如何解决绩效考核中“手松手紧”的问题

遇到的问题&#xff1a; l 评价时不同领导评分标准宽严程度不一&#xff0c;主观影响大 “严父”型领导&#xff0c;评分标准较高&#xff0c;严格评分&#xff0c;导致得分偏低。 “慈母”型领导&#xff0c;评分标准较低&#xff0c;评分宽松&#xff0c;导致得分偏高。…

区块链dapp开发 dapp系统开发方案

在区块链技术的兴起和普及的推动下&#xff0c;去中心化应用程序&#xff08;DApp&#xff09;成为了当前数字世界中的热门话题之一。DApp 的开发不仅需要考虑技术方面的挑战&#xff0c;还需要深入了解区块链的工作原理和应用场景。本文将介绍一种 DApp 系统开发的基本方案&am…

PHP开发全新29网课交单平台源码修复全开源版本,支持聚合登陆易支付

这是一套最新版本的PHP开发的网课交单平台源代码&#xff0c;已进行全开源修复&#xff0c;支持聚合登录和易支付功能。 项目 地 址 &#xff1a; runruncode.com/php/19721.html 以下是对该套代码的主要更新和修复&#xff1a; 1. 移除了论文编辑功能。 2. 移除了强国接码…

Github 2024-03-28Go开源项目日报Top10

根据Github Trendings的统计,今日(2024-03-28统计)共有10个项目上榜。根据开发语言中项目的数量,汇总情况如下: 开发语言项目数量Go项目9非开发语言项目1Ollama: 本地大型语言模型设置与运行 创建周期:248 天开发语言:Go协议类型:MIT LicenseStar数量:42421 个Fork数量:…

Ubuntu18.04 下Ublox F9P 实现RTK (利用CORS服务无需自建基站)

本内容参考如下连接:Ubuntu下Ublox F9P利用CORS服务无需自建基站实现RTK-CSDN博客 一、Ublox F9P 硬件模块示意图 图中展示了Ublox F9P的接口,包括串口2(`UART1`和`UART2`),USB1。需要人为通过u-center(Ublox F9P的显示软件)软件设置以下功能: Ublox通过`UART1`向PC端发送…

Web Components使用(一)

在使用Web Components之前&#xff0c;我们先看看上一篇文章Web Components简介&#xff0c;其中提到了相关的接口、属性和方法。 正是这些接口、属性和方法才实现了Web Components的主要技术&#xff1a;Custom elements&#xff08;自定义元素&#xff09;、Shadow DOM&#…

百度智能云推出AI大模型全家桶;抖音发布 AI 生成虚拟人物治理公告

百度智能云推出大模型全家桶 百度智能云昨日在北京首钢园召开「Al Cloud Day: 大模型应用产品发布会」&#xff0c;此次发布会上&#xff0c;百度智能云宣布对以下 7 款产品进行升级。 数字人平台百度智能云曦灵智能客服平台百度智能云客悦内容创作平台「一念」知识智平台「甄…

GPT:多轮对话并搭建简单的聊天机器人

1 多轮对话 多轮对话能力至关重要&#xff0c;它不仅能深化交流&#xff0c;精准捕捉对方意图&#xff0c;还能促进有效沟通&#xff0c;增强理解。在智能客服、教育辅导等领域&#xff0c;多轮对话更是提升服务质量、增强用户体验的关键。 注意&#xff1a;大模型没有多轮对话…

Linux 安装部署高性能缓存服务redis

Linux 系统安装Redis 5 注意事项&#xff1a; 下载Redis 文件包&#xff0c;并上传至linux服务上解压 tar -zxvf redis.tar安装&#xff1a; 编译 make PREFIX/usr/local/redis install配置&#xff1a; redis.conf daemonize yes bind 127.0.0.1 192.168.1.221 supervised…

进阶了解C++(6)——二叉树OJ题

Leetcode.606.根据二叉树创建字符串&#xff1a; 606. 根据二叉树创建字符串 - 力扣&#xff08;LeetCode&#xff09; 难度不大&#xff0c;根据题目的描述&#xff0c;首先对二叉树进行一次前序遍历&#xff0c;即&#xff1a; class Solution { public:string tree2str(Tr…