华为技术专家居然把JVM内存模型讲解这么细致「建议收藏」

大家好,又见面了,我是你们的朋友全栈君。

内存是非常重要的系统资源,是硬盘和CPU的中间仓库及桥梁,承载着os和应用程序的实时运行。 JVM内存布局规定了Java在运行过程中内存申请、分配、管理的策略,保证了JVM高效稳定运行。不同JVM对于内存的划分方式和管理机制存在差异。结合JVM虚拟机规范,来探讨经典JVM内存布局。

JVM运行时数据区

华为技术专家居然把JVM内存模型讲解这么细致「建议收藏」

线程独占 每个线程都会有它独立的空间,随线程生命周期而创建和销毁 线程共享 所有线程能访问这块内存数据,随虚拟机或者GC而创建和销毁 JDK8的JVM内存模型

华为技术专家居然把JVM内存模型讲解这么细致「建议收藏」

1 Program Counter Register (程序计数寄存器)

华为技术专家居然把JVM内存模型讲解这么细致「建议收藏」

Register 之名源于CPU的寄存器,CPU只有把数据装载到寄存器才能够运行 寄存器存储指令相关的现场信息,由于CPU时间片轮限制,众多线程在并发执行过程中,任何一个确定的时刻,一个%ignore_a_1%或者多核处理器中的一个内核,只会执行某个线程中的一条指令。这样必然导致经常中断或恢复,如何保证分毫无差呢? 每个线程在创建后,都会产生自己的程序计数器和栈帧,程序计数器用来存放执行指令的偏移量和行号指示器等,线程执行或恢复都要依赖程序计数器。程序计数器在各个线程之间互不影响,此区域也不会发生内存溢出异常。

1.1. 定义

这是一块较小的内存空间,可看作当前线程正在执行的字节码的行号指示器。如果当前线程正在执行的是:

Java方法 计数器记录的就是当前线程正在执行的字节码指令的地址本地方法 那么程序计数器值为undefined1.2. 作用

程序计数器(后文简称为 PCR)有两个作用:

字节码解释器通过改变PCR依次读取指令,实现代码的流程控制,如:顺序执行、选择、循环、异常处理多线程情况下,PCR用于记录当前线程执行的位置,从而当线程被切换回来的时候能够知道该线程上次运行到哪了1.3. 特点

一块较小的内存空间,【线程私有】。每条线程都有一个独立的程序计数器。 唯一一个不会出现OOM的内存区域。

2. Java虚拟机栈(JVM Stack)2.1. 定义

相对于基于寄存器的运行环境,JVM是基于栈结构的运行环境。栈结构移植性更好,可控性更强。

JVM中的虚拟机栈是描述Java方法执行的内存区域,属【线程私有】。

栈中的元素用于支持虚拟机进行方法调用,每个方法从开始调用到执行完成的过程,就是栈帧从入栈到出栈的过程。

2.2 结构

栈帧是方法运行的基本结构。

在活动线程中,只有位于栈顶的帧才是有效的,称为当前栈帧正在执行的方法称为当前方法

在执行引擎运行时,所有指令都只能针对当前栈帧操作,StackOverflowError表示请求的栈溢出,导致内存耗尽,通常出现在递归方法。

当前方法的栈帧,都是正在战斗的战场,其中的操作栈是参与战斗的士兵

操作栈的压栈与出栈

华为技术专家居然把JVM内存模型讲解这么细致「建议收藏」

虚拟机栈通过压/出栈,对每个方法对应的活动栈帧进行运算处理,方法正常执行结束,肯定会跳转到另一个栈帧上。 在执行的过程中,如果出现异常,会进行异常回溯,返回地址通过异常处理表确定。

栈帧在整个JVM体系中的地位颇高,包括:局部变量表、操作栈、动态连接、方法返回地址等。

局部变量表

存放方法参数和局部变量。 相对于类属性变量的准备阶段和初始化阶段,局部变量没有准备阶段,必须显式初始化。 如果是非静态方法,则在index[0]位置上存储的是方法所属对象的实例引用,随后存储的是参数和局部变量。 字节码指令中的STORE指令就是将操作栈中计算完成的局部变量写回局部变量表的存储空间内。

操作数栈

一个初始状态为空的桶式结构栈。由于 Java 没有寄存器,所有参数传递使用操作数栈。在方法执行过程中,会有各种指令往栈中写入和提取信息。JVM的执行引擎是基于栈的执行引擎,其中的栈指的就是操作栈。

字节码指令集的定义都是基于栈类型的,栈的深度在方法元信息的stack属性中。

操作栈与局部变量表交互

华为技术专家居然把JVM内存模型讲解这么细致「建议收藏」

详细的字节码操作顺序如下:

华为技术专家居然把JVM内存模型讲解这么细致「建议收藏」

第1处说明:局部变量表就像个中药柜,里面有很多抽屉,依次编号为0, 1, 2,3,.,. n 字节码指令istore_ 1就是打开1号抽屉,把栈顶中的数13存进去 栈是一个很深的竖桶,任何时候只能对桶口元素进行操作,所以数据只能在栈顶进行存取

某些指令可以直接在抽屉里进行,比如inc指令,直接对抽屉里的数值进行+1操作 程序员面试过程中,常见的i++和++i的区别,可以从字节码上对比出来

华为技术专家居然把JVM内存模型讲解这么细致「建议收藏」

iload_ 1 从局部变量表的第1号抽屉里取出一个数,压入栈顶,下一步直接在抽屉里实现+1的操作,而这个操作对栈顶元素的值没有影响 所以istore_ 2只是把栈顶元素赋值给a表格右列,先在第1号抽屉里执行+1操作,然后通过iload_ 1 把第1号抽屉里的数压入栈顶,所以istore_ 2存入的是+1之后的值

i++并非原子操作。即使通过volatile关键字进行修饰,多个线程同时写的话,也会产生数据互相覆盖的问题。

动态连接

每个栈帧中包含一个在常量池中对当前方法的引用,目的是支持方法调用过程的动态连接。

方法返回地址

方法执行时有两种退出情况:

正常退出 正常执行到任何方法的返回字节码指令,如RETURN、IRETURN、ARETURN等。异常退出

无论何种,都将返回至方法当前被调用的位置。方法退出的过程相当于弹出当前栈帧。

退出可能有三种方式:

返回值压入,上层调用栈帧异常信息抛给能够处理的栈帧PC计数器指向方法调用后的下一条指令

Java虚拟机栈是描述Java方法运行过程的内存模型。Java虚拟机栈会为每一个即将运行的Java方法创建“栈帧”。用于存储该方法在运行过程中所需要的一些信息。

局部变量表 存放基本数据类型变量、引用类型的变量、returnAddress类型的变量操作数栈动态链接当前方法的常量池指针当前方法的返回地址方法出口等信息

每一个方法从被调用到执行完成的过程,都对应着一个个栈帧在JVM栈中的入栈和出栈过程

特点

局部变量表的创建是在方法被执行的时候,随栈帧创建而创建。 表的大小在编译期就确定,在创建的时候只需分配事先规定好的大小即可。在方法运行过程中,表的大小不会改变。Java虚拟机栈会出现两种异常:

StackOverFlowError 若Java虚拟机栈的内存大小不允许动态扩展,那么当线程请求的栈深度大于虚拟机允许的最大深度时(但内存空间可能还有很多),就抛出此异常 栈内存默认最大是1M,超出则抛出StackOverflowError OutOfMemoryError 若Java虚拟机栈的内存大小允许动态扩展,且当线程请求栈时内存用完了,无法再动态扩展了,此时抛出OutOfMemoryError异常

Java虚拟机栈也是线程私有的,每个线程都有各自的Java虚拟机栈,而且随着线程的创建而创建,随线程的死亡而死亡。

3. 本地方法栈(Native Method Stack)

和虚拟机栈功能类似,虚拟机栈是为虚拟机执行JAVA方法而准备的。虚拟机规范并未规定具体实现,由不同虚拟机厂商自行实现。 HotSpot虚拟机中虚拟机栈和本地方法栈的实现式一样的。

本地方法栈和Java虚拟机栈实现的功能与抛出异常几乎相同。只不过

虚拟机栈是为虚拟机执行Java方法(也就是字节码)服务本地方法栈则为虚拟机使用到的Native方法服务

在JVM内存布局中,也是线程对象私有的,但是虚拟机栈“主内”,而本地方法栈“主外”。 这个“内外”是针对JVM来说的,本地方法栈为Native方法服务线程开始调用本地方法时,会进入一个不再受JVM约束的世界。本地方法可以通过JNI(Java Native Interface)访问虚拟机运行时的数据区,甚至可以调用寄存器,具有和JVM相同的能力和权限。

当大量本地方法出现时,势必会削弱JVM对系统的控制力,因为它的出错信息都比较黑盒。对于内存不足的情况,本地方法栈还是会拋出native heap OutOfMemory。

最著名的本地方法应该是System.currentTimeMillis(),JNI 使Java深度使用OS的特性功能,复用非Java代码。但在项目过程中,如果大量使用其他语言来实现JNI,就会丧失跨平台特性,威胁到程序运行的稳定性。假如需要与本地代码交互,就可以用中间标准框架进行解耦,这样即使本地方法崩溃也不至于影响到JVM的稳定。当然,如果要求极高的执行效率、偏底层的跨进程操作等,可以考虑设计为JNI调用方式。

4 Java堆(Java Heap)

JVM启动时创建,存放所有的类实例及数组对象。 除实例数据,还保存对象的其他信息,如Mark Word(存储对象哈希码,GC标志,GC年龄,同步锁等信息),Klass Pointy(指向存储类型元数据的指针)及一些字节对齐补白的填充数据(若实例数据刚好满足8字节对齐,则可不存在补白)。

垃圾回收器主要就是管理堆内存。 Heap是OOM主要发源地,它存储着几乎所有的实例对象,堆由垃圾收集器自动回收,由各子线程共享使用。通常它占用的空间是所有内存区域中最大的,但若无节制创建大量对象,也容易消耗完所有空间。

堆的内存空间,既可以固定大小,也可运行时动态调整,通过如下参数设定初始值和最大值,比如

代码语言:javascript代码运行次数:0运行复制

-Xms 256M-Xmx 1024M

其中-X表示它是JVM运行参数

ms是memorystart的简称,最小堆容量mx是memory max的简称,最大堆容量

通常情况下,服务器在运行过程中,堆空间不断地扩容与回缩,势必形成不必要系统压力,所以在线上生产环境中,JVM的Xms和Xmx设置成一样大小,避免在GC后调整堆大小时带来的额外压力。

堆分成两大块:新生代和老年代 对象产生之初在新生代,步入暮年时进入老年代,但是老年代也接纳在新生代无法容纳的超大对象。

新生代

1个Eden区+ 2个Survivor区。绝大部分对象在Eden区生成,当Eden区填满,会触发Young GC(后文简称YGC)。GC时,在Eden区实现清除策略,没有被引用的对象则直接回收。依然存活的对象会被复制到Survivor区。

Survivor 区分为S0和S1两块内存空间,送到哪块空间呢? 每次YGC时,将存活的对象复制到未使用的那块空间,然后将当前正在使用的空间完全清除,交换两块空间的使用状态。 若YGC要移送的对象大于Survivor区容量上限,则直接移交给老年代。假如一些没有进取心的对象以为可以一直在新生代的Survivor区交换来交换去,那就错了。每个对象都有一个计数器,每次YGC都会加1。

代码语言:javascript代码运行次数:0运行复制

-XX:MaxTenuringThreshold 

参数能配置计数器的值到达某个阈值的时候,对象从新生代晋升至老年代。若该参数配置为1,则从新生代的Eden区直接移至老年代。

默认值是15

华为技术专家居然把JVM内存模型讲解这么细致「建议收藏」

可以在Survivor 区交换14次之后,晋升至老年代

对象分配与简要GC流程图

华为技术专家居然把JVM内存模型讲解这么细致「建议收藏」

Survivor区无法放下,或超大对象的阈值超过上限,则尝试在老年代中进行分配。 若老年代也无法放下,则会触发Full Garbage Collection(Full GC),若依然无法放下,则抛OOM。

堆出现OOM的概率是所有内存耗尽异常中最高的,出错时的堆内信息对解决问题非常有帮助,所以给JVM设置运行参数

代码语言:javascript代码运行次数:0运行复制

-XX:+HeapDumpOnOutOfMemoryError

让JVM遇到OOM异常时能输出堆内信息。

特点

Java虚拟机所需要管理的内存中最大的一块.

堆内存物理上不一定要连续,只需要逻辑上连续即可,就像磁盘空间一样. 堆是垃圾回收的主要区域,所以也被称为GC堆.

堆的大小既可以固定也可以扩展,但主流的虚拟机堆的大小是可扩展的(通过-Xmx和-Xms控制),因此当线程请求分配内存,但堆已满,且内存已满无法再扩展时,就抛出OutOfMemoryError.

线程共享 整个Java虚拟机只有一个堆,所有的线程都访问同一个堆. 它是被所有线程共享的一块内存区域,在虚拟机启动时创建. 而程序计数器、Java虚拟机栈、本地方法栈都是一个线程对应一个

5 方法区5.1 定义

Java虚拟机规范中定义方法区是堆的一个逻辑区划部分,具体实现根据不同虚拟机来实现。 HotSpot在:

JDK7时,方法区放在永久代JDK8时,方法区放在元数据空间,通过GC对该区域进行管理

别名Non-Heap(非堆),以与Java堆区分。

方法区主要存放已经被虚拟机加载的类型的相关信息:

类信息 类名、访问修饰符、字段描述、方法描述运行时常量池 常量存储在【运行时常量池】静态变量即时编译器(JIT)编译后的代码等数据5.2 特点线程共享 方法区是堆的一个逻辑部分,因此和堆一样,线程共享。整个虚拟机只有一个方法区。永久代 方法区中的信息一般需长期存在,且又是堆的逻辑分区,因此用堆的划分方法,把方法区称为永久代内存回收效率低 Java虚拟机规范对方法区的要求比较宽松,可不实现GC。方法区中的信息一般需长期存在,回收一遍内存后,可能只有少量信息无效。对方法区的内存回收的主要目标是: 常量池的回收类型的卸载

和堆一样,允许固定大小,也可扩展大小,还允许不实现GC。

当方法区内存空间无法满足内存分配需求时,将抛出OutOfMemoryError异常.

5.3 运行时常量池(Runtime Constant Pool)5.3.1 定义

方法区的一部分。

.java文件被编译后生成的.class文件中除了包含:类的版本、字段、方法、接口等描述信息,还有常量池。

常量池存放编译时期产生的各种:

字面量 符号引用

.class文件中的常量池中的所有的内容在类被加载后存放到方法区的运行时常量池中。

代码语言:javascript代码运行次数:0运行复制

// age 是一个变量,可被赋值// 21 是一个字面值常量,不能被赋值PS:int age = 21; // pai 是一个符号常量,一旦被赋值之后就不能被修改int final pai = 3.14;

JDK6、7、8三个版本中, 运行时常量池的所处区域一直在不断的变化:

6时,是方法区的一部分7时,又放到堆内存8时,出现了元空间,又回到了方法区

这也说明了官方对“永久代”的优化从7就已经开始了。

5.3.2 特性

运行时常量池相比class文件常量池的另外一个特性是具备动态性,Java语言并不要求常量一定只有编译器才产生,即并非预置入class文件中常量池的内容才能进入方法区运行时常量池,运行期间也可能将新的常量放入池。

String类的intern()方法就采用了运行时常量池的动态性。调用 intern 时,看池中是否已包含等于此 String 对象的字符串:

是 返回池中的字符串否 将此 String 对象添加到池中,并返回此 String 对象的引用5.3.3 可能抛出的异常

运行时常量池是方法区的一部分,所以会受到方法区内存的限制,因此当常量池无法再申请到内存时,就会抛OutOfMemoryError异常。

一般在一个类中通过public static final声明一个常量。该类被编译后便生成Class文件,该类的所有信息都存储在这个class文件中。当这个类被JVM加载后,class文件中的常量就存放在方法区的运行时常量池。当运行时常量池中的某些常量没有被对象引用,同时也没有被变量引用,那么就需要垃圾收集器回收。

6 直接内存(Direct Memory)

直接内存不是虚拟机运行时数据区的一部分,也不是JVM规范中定义的内存区域,但在JVM的实际运行过程中会频繁地使用这块区域,而且也会抛OOM 。

JDK 1.4引入NIO(New Input/Output)类,一种基于管道和缓冲区的I/O方式,可使用Native函数库直接分配堆外内存,然后通过一个存储在堆里的DirectByteBuffer对象作为这块内存的引用来操作堆外内存中的数据。 这样能在一些场景中显著提升性能,因为避免了在Java堆和Native堆中来回复制数据。

7 Metaspace (元空间)

到了JDK8,元空间的前身Perm区(永久代)被淘汰,在JDK7及之前的版本中,只有Hotspot才有Perm区,它在启动时固定大小,很难调优,并且Full GC时会移动类元信息。

在某些场景下,若动态加载类过多,容易产生Perm区的OOM。比如某工程因为功能点较多,运行过程中,要不断动态加载很多类,经常出现错误:

代码语言:javascript代码运行次数:0运行复制

Exception in thread ‘dubbo client x.x connector' java.lang.OutOfMemoryError: PermGenspac

为解决该问题,需要设定运行参数

代码语言:javascript代码运行次数:0运行复制

-XX:MaxPermSize=1280m

如果部署到新机器上,往往会因为JVM参数没有修改导致故障再现。不熟悉此应用的人排查问题时都苦不堪言。此外,永久代在GC过程中还存在诸多问题。

所以,JDK8使用元空间替换永久代。不同于永久代,元空间在本地内存中分配。即 只要本地内存足够,它不会出现类似永久代的java.lang.OutOfMemoryError: PermGen space

对永久代的设置参数 PermSizeMaxPermSize也会失效。在JDK8及以上版本,设定MaxPermSize参数,JVM在启动时并不会报错,但提示:

代码语言:javascript代码运行次数:0运行复制

Java HotSpot 64Bit Server VM warning:ignoring option MaxPermSize=2560m; support was removed in 8.0

默认情况下,“元空间”大小:

可动态调整或使用新参数MaxMetaspaceSize限制本地内存分配给类元数据的大小

JDK8里,Perm 区所有内容中

字符串常量,移至堆内存其他内容包括类元信息、字段、静态属性、方法、常量等,移动至元空间

华为技术专家居然把JVM内存模型讲解这么细致「建议收藏」

如上图中的Object类元信息、静态属性System.out、整型常量000000等,图中显示在常量池中的String,其实际对象被保存在堆内存。

特点充分利用Java语言规范:类及相关元数据的生命周期与类加载器一致每个类加载器都有其内存区域-元空间只进行线性分配不会单独回收某个类(除了重定义类 RedefineClasses 或类加载失败)无GC扫描或压缩元空间里的对象不会被转移若GC发现某个类加载器不再存活,会对整个元空间进行集体回收GCFull GC时,指向元数据指针都不用再扫描,减少了Full GC的时间很多复杂的元数据扫描的代码(尤其是CMS里面的那些)都删除了元空间只有少量的指针指向Java堆 这包括:类的元数据中指向java.lang.Class实例的指针;数组类的元数据中,指向java.lang.Class集合的指针。无元数据压缩的开销减少了GC Root的扫描(不在扫描虚拟机里面的已加载类的目录和其它的内部哈希表)G1中,并发标记阶段完成后就可以进行类的卸载元空间内存分配模型绝大多数的类元数据的空间都在本地内存中分配用来描述类元数据的对象也被移除为元数据分配了多个映射的虚拟内存空间为每个类加载器分配一个内存块列表 块的大小取决于类加载器的类型Java反射的字节码存取器(sun.reflect.DelegatingClassLoader )占用内存更小空闲块内存返还给块内存列表当元空间为空,虚拟内存空间会被回收减少了内存碎片

从线程共享角度来看

堆和元空间,线程共享虚拟机栈、本地方法栈、程序计数器,线程私有

从这个角度看一下Java内存结构

华为技术专家居然把JVM内存模型讲解这么细致「建议收藏」

8 从GC角度看Java堆

堆和方法区都是线程共享的区域,主要用来存放对象的相关信息。一个接口中的多个实现类需要的内存可能不一样,一个方法中的多个分支需要的内存也可能不一样,我们只有在程序运行期间才能知道会创建哪些对象,因此, 这部分的内存和回收都是动态的,垃圾收集器所关注的就是这部分内存(本节后续所说的“内存”分配与回收也仅指这部分内存)。而在JDK1.7和1.8对这部分内存的分配也有所不同:

Java8中堆内存分配如下图:

华为技术专家居然把JVM内存模型讲解这么细致「建议收藏」

9 JVM关闭正常关闭:当最后一个非守护线程结束或调用了System.exit或通过其他特定于平台的方式,比如ctrl+c。强制关闭:调用Runtime.halt方法,或在操作系统中直接kill(发送single信号)掉JVM进程。异常关闭:运行中遇到RuntimeException 异常等

在某些情况下,我们需要在JVM关闭时做一些扫尾的工作,比如删除临时文件、停止日志服务。为此JVM提供了关闭钩子(shutdown hocks)来做这些事件。

Runtime类封装java应用运行时的环境,每个java应用程序都有一个Runtime类实例,使用程序能与其运行环境相连。

关闭钩子本质上是一个线程(也称为hock线程),可通过Runtime的addshutdownhock (Thread hock)向主jvm注册一个关闭钩子。hock线程在jvm正常关闭时执行,强制关闭不执行。

对于在JVM中注册的多个关闭钩子,他们会并发执行,JVM并不能保证他们的执行顺序。

《码出高效》

发布者:全栈程序员栈长,转载请注明出处:https://javaforall.cn/141995.html原文链接:https://javaforall.cn

以上就是华为技术专家居然把JVM内存模型讲解这么细致「建议收藏」的详细内容,更多请关注创想鸟其它相关文章!

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。
如发现本站有涉嫌抄袭侵权/违法违规的内容, 请发送邮件至 chuangxiangniao@163.com 举报,一经查实,本站将立刻删除。
发布者:程序猿,转转请注明出处:https://www.chuangxiangniao.com/p/30165.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2025年11月3日 15:57:54
下一篇 2025年11月3日 16:02:29

相关推荐

  • 怎样用免费工具美化PPT_免费美化PPT的实用方法分享

    利用KIMI智能助手可免费将PPT美化为科技感风格,但需核对文字准确性;2. 天工AI擅长优化内容结构,提升逻辑性,适合高质量内容需求;3. SlidesAI支持语音输入与自动排版,操作便捷,利于紧急场景;4. Prezo提供多种模板,自动生成图文并茂幻灯片,适合学生与初创团队。 如果您有一份内容完…

    2025年12月6日 软件教程
    100
  • Pages怎么协作编辑同一文档 Pages多人实时协作的流程

    首先启用Pages共享功能,点击右上角共享按钮并选择“添加协作者”,设置为可编辑并生成链接;接着复制链接通过邮件或社交软件发送给成员,确保其使用Apple ID登录iCloud后即可加入编辑;也可直接在共享菜单中输入邮箱地址定向邀请,设定编辑权限后发送;最后在共享面板中管理协作者权限,查看实时在线状…

    2025年12月6日 软件教程
    200
  • REDMI K90系列正式发布,售价2599元起!

    10月23日,redmi k90系列正式亮相,推出redmi k90与redmi k90 pro max两款新机。其中,redmi k90搭载骁龙8至尊版处理器、7100mah大电池及100w有线快充等多项旗舰配置,起售价为2599元,官方称其为k系列迄今为止最完整的标准版本。 图源:REDMI红米…

    2025年12月6日 行业动态
    200
  • Linux中如何安装Nginx服务_Linux安装Nginx服务的完整指南

    首先更新系统软件包,然后通过对应包管理器安装Nginx,启动并启用服务,开放防火墙端口,最后验证欢迎页显示以确认安装成功。 在Linux系统中安装Nginx服务是搭建Web服务器的第一步。Nginx以高性能、低资源消耗和良好的并发处理能力著称,广泛用于静态内容服务、反向代理和负载均衡。以下是在主流L…

    2025年12月6日 运维
    000
  • Linux journalctl与systemctl status结合分析

    先看 systemctl status 确认服务状态,再用 journalctl 查看详细日志。例如 nginx 启动失败时,systemctl status 显示 Active: failed,journalctl -u nginx 发现端口 80 被占用,结合两者可快速定位问题根源。 在 Lin…

    2025年12月6日 运维
    100
  • 华为新机发布计划曝光:Pura 90系列或明年4月登场

    近日,有数码博主透露了华为2025年至2026年的新品规划,其中pura 90系列预计在2026年4月发布,有望成为华为新一代影像旗舰。根据路线图,华为将在2025年底至2026年陆续推出mate 80系列、折叠屏新机mate x7系列以及nova 15系列,而pura 90系列则将成为2026年上…

    2025年12月6日 行业动态
    100
  • Linux如何优化系统性能_Linux系统性能优化的实用方法

    优化Linux性能需先监控资源使用,通过top、vmstat等命令分析负载,再调整内核参数如TCP优化与内存交换,结合关闭无用服务、选用合适文件系统与I/O调度器,持续按需调优以提升系统效率。 Linux系统性能优化的核心在于合理配置资源、监控系统状态并及时调整瓶颈环节。通过一系列实用手段,可以显著…

    2025年12月6日 运维
    000
  • 曝小米17 Air正在筹备 超薄机身+2亿像素+eSIM技术?

    近日,手机行业再度掀起超薄机型热潮,三星与苹果已相继推出s25 edge与iphone air等轻薄旗舰,引发市场高度关注。在此趋势下,多家国产厂商被曝正积极布局相关技术,加速抢占这一细分赛道。据业内人士消息,小米的超薄旗舰机型小米17 air已进入筹备阶段。 小米17 Pro 爆料显示,小米正在评…

    2025年12月6日 行业动态
    000
  • 荣耀手表5Pro 10月23日正式开启首销国补优惠价1359.2元起售

    荣耀手表5pro自9月25日开启全渠道预售以来,市场热度持续攀升,上市初期便迎来抢购热潮,一度出现全线售罄、供不应求的局面。10月23日,荣耀手表5pro正式迎来首销,提供蓝牙版与esim版两种选择。其中,蓝牙版本的攀登者(橙色)、开拓者(黑色)和远航者(灰色)首销期间享受国补优惠价,到手价为135…

    2025年12月6日 行业动态
    000
  • Vue.js应用中配置环境变量:灵活管理后端通信地址

    在%ignore_a_1%应用中,灵活配置后端api地址等参数是开发与部署的关键。本文将详细介绍两种主要的环境变量配置方法:推荐使用的`.env`文件,以及通过`cross-env`库在命令行中设置环境变量。通过这些方法,开发者可以轻松实现开发、测试、生产等不同环境下配置的动态切换,提高应用的可维护…

    2025年12月6日 web前端
    000
  • 环境搭建docker环境下如何快速部署mysql集群

    使用Docker Compose部署MySQL主从集群,通过配置文件设置server-id和binlog,编写docker-compose.yml定义主从服务并组网,启动后创建复制用户并配置主从连接,最后验证数据同步是否正常。 在Docker环境下快速部署MySQL集群,关键在于合理使用Docker…

    2025年12月6日 数据库
    000
  • Linux文件系统rsync命令详解

    rsync通过增量同步高效复制文件,支持本地及远程同步,常用选项包括-a、-v、-z和–delete,结合SSH可安全传输数据,配合cron可实现定时备份。 rsync 是 Linux 系统中一个非常强大且常用的文件同步工具,能够高效地在本地或远程系统之间复制和同步文件与目录。它以“增量…

    2025年12月6日 运维
    000
  • RTX 5090性能怪兽!雷蛇灵刃18 2025游戏本图赏

    10月25日,雷蛇正式推出全新灵刃18 2025款旗舰级游戏笔记本,首发搭载nvidia rtx 50系列显卡,起售价为25999元。 目前该机型已抵达评测室,以下为实机图赏。 新款灵刃18配备一块18英寸双模屏幕,支持UHD+ 240Hz与FHD+ 440Hz两种显示模式,响应时间最快可达3ms。…

    2025年12月6日 行业动态
    000
  • Xbox删忍龙美女角色 斯宾塞致敬板垣伴信被喷太虚伪

    近日,海外游戏推主@HaileyEira公开发表言论,批评Xbox负责人菲尔·斯宾塞不配向已故的《死或生》与《忍者龙剑传》系列之父板垣伴信致敬。她指出,Xbox并未真正尊重这位传奇制作人的创作遗产,反而在宣传相关作品时对内容进行了审查和删减。 所涉游戏为年初推出的《忍者龙剑传2:黑之章》,该作采用虚…

    2025年12月6日 游戏教程
    000
  • 如何在mysql中分析索引未命中问题

    答案是通过EXPLAIN分析执行计划,检查索引使用情况,优化WHERE条件写法,避免索引失效,结合慢查询日志定位问题SQL,并根据查询模式合理设计索引。 当 MySQL 查询性能下降,很可能是索引未命中导致的。要分析这类问题,核心是理解查询执行计划、检查索引设计是否合理,并结合实际数据访问模式进行优…

    2025年12月6日 数据库
    000
  • VSCode入门:基础配置与插件推荐

    刚用VSCode,别急着装一堆东西。先把基础设好,再按需求加插件,效率高还不卡。核心就三步:界面顺手、主题舒服、功能够用。 设置中文和常用界面 打开软件,左边活动栏有五个图标,点最下面那个“扩展”。搜索“Chinese”,装上官方出的“Chinese (Simplified) Language Pa…

    2025年12月6日 开发工具
    000
  • VSCode性能分析与瓶颈诊断技术

    首先通过资源监控定位异常进程,再利用开发者工具分析性能瓶颈,结合禁用扩展、优化语言服务器配置及项目设置,可有效解决VSCode卡顿问题。 VSCode作为主流的代码编辑器,虽然轻量高效,但在处理大型项目或配置复杂扩展时可能出现卡顿、响应延迟等问题。要解决这些性能问题,需要系统性地进行性能分析与瓶颈诊…

    2025年12月6日 开发工具
    000
  • php查询代码怎么写_php数据库查询语句编写技巧与实例

    在PHP中进行数据库查询,最常用的方式是使用MySQLi或PDO扩展连接MySQL数据库。下面介绍基本的查询代码写法、编写技巧以及实用示例,帮助你高效安全地操作数据库。 1. 使用MySQLi进行查询(面向对象方式) 这是较为推荐的方式,适合大多数中小型项目。 // 创建连接$host = ‘loc…

    2025年12月6日 后端开发
    000
  • 如何在mysql中定期清理过期备份文件

    通过Shell脚本结合cron定时任务实现MySQL过期备份文件自动清理,首先统一备份命名格式(如backup_20250405.sql)并存放在指定目录(/data/backup/mysql),然后编写脚本使用find命令删除7天前的.sql文件,配置每日凌晨2点执行的cron任务,并加入日志记录…

    2025年12月6日 数据库
    000
  • 重现iPhone X颠覆性时刻!苹果2027年跳过19命名iPhone 20

    10月23日,有消息称,苹果或将再次调整iPhone的发布节奏,考虑跳过“iPhone 19”,并于2027年直接推出“iPhone 20”系列。 此举据传是为了庆祝初代iPhone发布二十周年,同时开启新一轮的设计革新,目标是复刻2017年iPhone X带来的划时代变革。 据悉,苹果或将告别长期…

    2025年12月6日 手机教程
    000

发表回复

登录后才能评论
关注微信