Java中JVM常用参数配置(提供配置示例)

目录

    • 前言
    • 一、内存参数配置
    • 二、垃圾收集器配置
    • 三、GC策略配置
      • 3.1、基础通用配置
      • 3.2、Parallel 和 Parallel Old 常用参数配置
      • 3.3、CMS 常用参数配置
      • 3.4、G1 常用参数配置
    • 四、GC日志配置
    • 五、dump 日志参数配置
      • 5.1、OutOfMemory异常时生成dump文件
      • 5.2、发生Full GC时生成dump文件
    • 六、其它参数配置
    • 七、配置示例
      • 7.1、在IDEA中配置JVM参数
      • 7.2、通过 Java -jar 启动配置

前言

      在实际开发和部署中一个合格的码农都会对JVM的一些参数做合理的配置,比如内存配置参数、GC策略配置参数、日志配置参数、异常信息参数等,本文会列出一些常用的JVM参数以及通过一些例子演示配置后的效果。

PS:本文使用JDK1.8

一、内存参数配置

// 设置JVM使Server模式,特点是启动速度较慢,但运行时性能和内存管理效率很高,适用于生产环境。在具有64位能力的JDK环境下默认启用该模式。
-server // 设置元空间最大值, 默认是-1, 即不限制, 或者说只受限于本地内存大小,如果超过这个值会内存溢出。
-XX:MaxMetaspaceSize=256m
// 指定元空间触发Fullgc的初始阈值(元空间无固定初始大小), 以字节为单位,默认是21M,达到该值就会触发full gc进行类型卸载, 同时收集器会对该值进行调整: 如果释放了大量的空间, 就适当降低该值; 如果释放了很少的空间, 那么在不超过-XX:MaxMetaspaceSize(如果设置了的话) 的情况下, 适当提高该值。这个跟早期jdk版本的-XX:PermSize参数意思不一样,-XX:PermSize代表永久代的初始容量。
// 触发一次元空间Full GC后就会重新计算该值,建议设置成和最大内存一致
-XX:MetaspaceSize=256m// 设置最大堆内存,默认是物理内存的1/4,内存的单位可以是m g,并且不区分大小写
-Xmx2g 或者 -XX:MaxHeapSize=2048m
// 设置初始值堆内存,默认是物理内存的1/64,内存的单位可以是m g,并且不区分大小写
-Xms2g 或者 -XX:InitialHeapSize=2048m
// 设置年轻代内存大小,默认和老年代1\2,-XX:NewSize初始化年轻代大小 -XX:MaxNewSize最大年轻代大小
-Xmn1g 或者 -XX:NewSize=1g -XX:MaxNewSize=1g
// 设置每个线程的堆栈大小 默认是1024k,这个是最大内存并不是开启一个线程马上就会消耗这么多内存
-Xss512k 或者 -XX:ThreadStackSize=512k// 年轻代占用堆比例(如果有配置-Xmn,那么会以-Xmn配置为准)
// 默认 -XX:NewRatio=2新生代占1,老年代占2,年轻代占整个堆的1/3
// 假如 -XX:NewRatio=4新生代占1,老年代占4,年轻代占整个堆的1/5 NewRatio值就是设置老年代的占比,剩下的1给新生代
-XX:NewRatio=2 
// 用来设置新生代中eden空间和from/to空间的比例.含义:-设置为8代表 eden使用80%的新生代内存 from和to各用10%,默认为8
-XX:SurvivorRatio=8
// 禁用Survivor区自适应策略默认是开启的,如果不关闭这个配置新生代eden区和s0 s1区会在gc后自动调整大小,如果设置了-XX:SurvivorRatio也只有在没有GC之前有效只要GC后就会重新动态计算
-XX:-UseAdaptiveSizePolicy// 扩张堆内存的时机
// 堆内存使用率大于70时扩张堆内存,如果最大堆内存=初始堆内存时该参数无效,默认值70
-XX:MaxHeapFreeRatio=70
// 缩小堆内存的时机
// 堆内存使用率小于40时缩减堆内存,如果最大堆内存=初始堆内存时该参数无效,默认值40
-XX:MinHeapFreeRatio=40// 字符串常量池hash桶大小 类似于HashTable,最小值1009 默认60013 不可动态扩容
-XX:StringTableSize=60013// 设置直接内存大小,NIO(Non-blocking I/O)中通过ByteBuffer等对象分配的堆外内存
// 默认情况下,直接内存的大小可能会与Java堆的最大值 (-Xmx) 相同
-XX:MaxDirectMemorySize=512m

二、垃圾收集器配置

// 配置使用Serial单线程垃圾收集器,虚拟机运行在Client模式下的默认值
// 新生代使用Serial  老年代则使用SerialOld
-XX:+UseSerialGC// 配置使用ParNew垃圾收集器
// 新生代使用ParNew 老年代则使用Serial Old
-XX:+UseParNewGC// 配置使用Parallel Scavenge垃圾收集器,虚拟机运行在Server模式下的默认值
// 新生代使用Parallel Scavenge 老年代使用Parallel Old收集器
-XX:+UseParallelGC// 配置使用Parallel Old垃圾收集器
// 新生代使用Parallel Scavenge 老年代使用Parallel Old收集器
-XX:+UseParallelOldGC// 配置使用CMS垃圾收集器
// 新生代使用ParNew 老年代使用CMS+Serial Old收集器
-XX:+UseConcMarkSweepGC// 配置使用G1垃圾收集器
-XX:+UseG1GC

可以通过jinfo -flags 进程号查看对应Java程序启动参数,我本地使用的JDK1.8默认使用的ParallelGC
在这里插入图片描述

三、GC策略配置

3.1、基础通用配置

// GC停顿时间,垃圾收集器会尝试用各种手段达到这个时间,比如减小年轻代
-XX:MaxGCPauseMillis // 新生代晋升老年代阈值 默认是15 不同回收算法不同
-XX:MaxTenuringThreshold=15// 对象动态年龄判断默认50%  当一批对象大小>=survivor区的50%时这批对象会直接放入老年代
-XX:TargetSurvivorRatio=50// 默认值是0没有限制 大于这个值的参数直接在老年代分配
// 这样做的目的是避免在Eden区和两个Survivor区之间发生大量的内存复制XX:PretenureSizeThreshold=1m// 忽略手动调用GC, System.gc()的调用就会变成一个空调用,完全不触发GC
-XX:+DisableExplicitGC // 内存页的大小
-XX:LargePageSizeInBytes=128m // 设定GMT区域,避免CentOS坑爹的时区设置
-Duser.timezone=GMT+8// FullGC 前执行MinorGC  默认是开启的
-XX:+ScavengeBeforeFullGC

3.2、Parallel 和 Parallel Old 常用参数配置

// 调整垃圾回收的时间和总时间的占比 公式 1/(1+ratio)  ratio默认是99,100分钟运行时间默认不能超过1分钟的GC时间,ratio一般设置为19
-XX:GCTimeRatio=99// GC最大暂停毫秒数 默认是200毫秒 和-XX:+GCTimeRatio有冲突,堆内存小回收速度才会快,而-XX:+GCTimeRatio需要保证一定时间内GC时间不能超过一个临界值需要增加内存才能减小GC时间比,需要找到一个两个参数的合理值
-XX:MaxGCPauseMillis=200ms// 设置垃圾回收线程数量 默认是CUP内核数量
-XX:ParallelGCThreads=4

3.3、CMS 常用参数配置

// GC最大暂停毫秒数 默认是200毫秒
-XX:MaxGCPauseMillis=200ms// 为了加快此阶段处理速度,减少停顿时间,可以开启初始标记并行化
-XX:+CMSParallelInitialMarkEnabled// CMS并行线程数量,并行线程用于执行 CMS 垃圾回收器的并行阶段,如初始标记阶段和重新标记阶段
// 默认值为系统的逻辑处理器数量减1,目的是为了保留一个处理器用于应用程序线程
-XX:ParallelCMSThreads=3// CMS并发线程数量,并发线程用于执行 CMS 垃圾回收器的并发阶段,如初始标记阶段、并发标记阶段和并发清理阶段。
// 默认值为系统的逻辑处理器数量减1,目的是为了保留一个处理器用于应用程序线程
-XX:ConcGCThreads=3// 执行CMS的内存占比 percent=80 当我的老年代内存达到80%触发垃圾回收 默认是92% 应为CMS采用标记清除需要给浮动垃圾(在最后一步并发清除时其它没有被标记的垃圾遗留)预留空间 
-XX:CMSInitiatingOccupancyFraction=percent// 该参数需要配合XX:CMSInitiatingOccupancyFraction使用,只使用设定的回收阈值(-XX:CMSInitiatingOccupancyFraction设 定的值),如果不指定,JVM仅在第一次使用设定值,后续则会自动调整
-XX:+UseCMSInitiatingOccupancyOnly // 重新标记阶段前提前进行一次新生代GC,因为重新标记也会判断新生代对象是否引用老年代对象,有些时候新生代对象已经没有被GC root对象引用但是还没有GC时,重新标记会扫描到新生代对象并且保留新生代对象引用的老年代对象,默认关闭false
-XX:CMSScavengeBeforeRemark=true// 执行完Full GC后对内存空间进行压缩整理 默认开启
-XX:+UseCMSCompactAtFullGollection// 设置在执行多少次Full GC后对内存空间进行压缩整理 默认0次,只要触发Full GC就会进行内存压缩
-XX:CMSFullGCsBeforeCompaction=0// 垃圾回收时是否同时卸载不用的class信息,默认关闭
-XX:+CMSClassUnloadingEnabled

3.4、G1 常用参数配置

// 指定分区大小(1MB~32MB,且必须是2的N次幂),不设置默认会根据堆大小分配
// 堆内存为1G默认1024个1MB分区、堆内存为2G默认2048个1MB分区、堆内存为4G默认2048个2MB分区、堆内存为4G默认2048个2MB分区、堆内存为6G默认6144个1MB分区、堆内存为8G默认2048个4MB分区、以此类推
-XX:G1HeapRegionSize=2m// 目标暂停时间(默认200ms) 
-XX:MaxGCPauseMillis=200ms// 新生代内存初始空间(默认整堆5%) 
-XX:G1NewSizePercent=5// 新生代内存最大空间 (默认整堆60%) 
-XX:G1MaxNewSizePercent=60// Survivor区的填充容量(默认50%),Survivor区域里的一批对象(年龄1+年龄2+年龄n的多个 年龄对象)总和超过了Survivor区域的50%,此时就会把年龄n(含)以上的对象都放入老年代 
-XX:TargetSurvivorRatio=50// 最大年龄阈值(默认15) 
-XX:MaxTenuringThreshold=15// 老年代占用空间达到整堆内存阈值(默认45%),则执行新生代和老年代的混合收集(MixedGC) 
-XX:InitiatingHeapOccupancyPercent=45// region中的存活对象低于这个值时才会回收该region,如果超过这个值,存活对象过多,回收的的意义不大(默认65%)。 
-XX:G1MixedGCLiveThresholdPercent=65// 在一次回收过程中指定做几次筛选回收(默认8次),在最后一个筛选回收阶段可以回收一会,然后暂停回收,恢复系统运行,一会再开始回收,这样可以让系统不至于单次停顿时间过长。 
-XX:G1MixedGCCountTarget=8// gc过程中空出来的region是否充足阈值,在混合回收的时候,对Region回收都是基于复制算法进行的,都是把要回收的Region里的存活对象放入其他Region,然后这个Region中的垃圾对象全部清理掉,这样的话在回收过程就会不断空出来新的Region,一旦空闲出来的Region数量达到了堆内存的5%,此时就会立即停止混合回收,意味着本次混合回收就结束了(默认5%)。
-XX:G1HeapWastePercent=5

四、GC日志配置

// 设置日志目录和日志名称
-Xloggc:/data/logs/gc-%t.log// 开启滚动生成日志 默认关闭
-XX:+UseGCLogFileRotation
// 滚动GC日志文件数,默认0不滚动,保留最多5个日志文件
-XX:NumberOfGCLogFiles=5
// GC文件滚动大小,需开启UseGCLogFileRotation,每个文件最大为20MB
-XX:GCLogFileSize=20M // 在进行GC的前后打印出堆的信息
-XX:+PrintHeapAtGC 
// 打印新生代晋升详情
-XX:+PrintTenuringDistribution
// 打印字符串常量池堆信息
-XX:+PrintStringTableStatistics
// 打印GC信息
-verbose:gc 
// 打印GC详细信息 
-XX:+PrintGCDetails
// 输出GC的时间戳(以基准时间的形式)
-XX:+PrintGCTimeStamps
// 输出GC的时间戳(以日期的形式,如 2013-05-04T21:53:59.234+0800)
-XX:+PrintGCDateStamps 
// 打印当前JVM参数信息 建议在每个程序中都添加上
-XX:+PrintCommandLineFlags
// 产生GC的原因(默认开启)
-XX:+PrintGCCause

五、dump 日志参数配置

5.1、OutOfMemory异常时生成dump文件

// 默认关闭
// 可以通过jinfo -flag [+|-]HeapDumpOnOutOfMemoryError <pid> 或 jinfo -flag HeapDumpOnOutOfMemoryError=<value> <pid> 来动态开启或设置值
-XX:+HeapDumpOnOutOfMemoryError
// 设置文件存储路径
// 当HeapDumpOnOutOfMemoryError开启的时候,dump文件的保存路径,默认为工作目录下的,可以通过配置指定保存路径
-XX:HeapDumpPath=/data/dump/jvm.hprof

5.2、发生Full GC时生成dump文件

不推荐开启会增加整体停顿时间

// 在Full GC前dump
-XX:+HeapDumpBeforeFullGC
// 在Full GC后dump
-XX:+HeapDumpAfterFullGC
// 设置Dump保存的路径
-XX:HeapDumpPath=/data/dump/jvm.hprof

六、其它参数配置

// JVM自身故障导致进程奔溃时,会有一个日志文件生成,它包含了导致crash的重要信息,通过分析文件来查找crash原因
-XX:ErrorFile=/data/logs/error.log// JDK1.6开始,默认server模式下开启了这个参数,意为当jvm检测到程序在重复抛一个异常
// 在执行若干次后会将异常吞掉,这里的若干次在jdk1.7测得是20707。即执行20707次后,stackTrace 长度会为0。有时这不利于我们排错,通过指定OmitStackTraceInFastThrow,可禁用这功能
-XX:-OmitStackTraceInFastThrow

七、配置示例

需要配置的参数信息

// 配置新生代使用Parallel Scavenge 老年代将会使用Parallel Old收集器
-XX:+UseParallelOldGC
// 配置元空间最大内存和初始内存
-XX:MaxMetaspaceSize=256m -XX:MetaspaceSize=256m
// 配置最大堆内存、初始内存、新生代占用内存
-Xmx512m -Xms512m -Xmn256m
// 配置关闭动态调整新生代eden和from to大小比例
-XX:-UseAdaptiveSizePolicy
// 配置忽略手动调用GC和时区
-XX:+DisableExplicitGC -Duser.timezone=GMT+8
// 配置开启记录OOM Dump信息和存储地址
-XX:+HeapDumpOnOutOfMemoryError -XX:HeapDumpPath=./jvm.hprof
// 配置打印当前JVM参数信息
-XX:+PrintCommandLineFlags
// 配置开启GC日志输出
-verbose:gc -XX:+PrintGCDetails -XX:+PrintHeapAtGC -XX:+PrintGCDateStamps -Xloggc:./gc-%t.log
// 配置关闭重复多次抛同一个异常不输出
-XX:-OmitStackTraceInFastThrow
// 配置JVM自身故障导致宕机时日志输出目录
-XX:ErrorFile=./error.log

7.1、在IDEA中配置JVM参数

  • 配置参数(注意文件的输出目录,我这里会直接输出在当前目录)
-XX:+UseParallelOldGC
-XX:MaxMetaspaceSize=256m -XX:MetaspaceSize=256m
-Xmx20m -Xms20m -Xmn10m
-XX:-UseAdaptiveSizePolicy
-XX:+DisableExplicitGC -Duser.timezone=GMT+8
-XX:+HeapDumpOnOutOfMemoryError -XX:HeapDumpPath=./jvm.hprof
-XX:+PrintCommandLineFlags
-verbose:gc -XX:+PrintGCDetails -XX:+PrintHeapAtGC -XX:+PrintGCDateStamps -Xloggc:./gc-%t.log
-XX:-OmitStackTraceInFastThrow
-XX:ErrorFile=./error.log
  • 配置流程
    在这里插入图片描述
    在这里插入图片描述
    在这里插入图片描述

7.2、通过 Java -jar 启动配置

# 应用配置示例
nohup java -XX:+UseParallelOldGC -XX:MaxMetaspaceSize=256m -XX:MetaspaceSize=256m -Xmx512m -Xms512m -Xmn256m -XX:-UseAdaptiveSizePolicy -XX:+DisableExplicitGC -Duser.timezone=GMT+8 -XX:+HeapDumpOnOutOfMemoryError -XX:HeapDumpPath=./jvm.hprof -XX:+PrintCommandLineFlags -verbose:gc -XX:+PrintGCDetails -XX:+PrintHeapAtGC -XX:+PrintGCDateStamps -Xloggc:./gc-%t.log -XX:-OmitStackTraceInFastThrow -XX:ErrorFile=./error.log -jar app.jar > app.log 2>&1 &

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

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

相关文章

PySpark(三)RDD持久化、共享变量、Spark内核制度,Spark Shuffle、Spark执行流程

目录 RDD持久化 RDD 的数据是过程数据 RDD 缓存 RDD CheckPoint 共享变量 广播变量 累加器 Spark 内核调度 DAG DAG 的宽窄依赖和阶段划分 内存迭代计算 Spark是怎么做内存计算的? DAG的作用?Stage阶段划分的作用? Spark为什么比MapReduce快&#xff1f; Spa…

Android Graphics 图像显示系统 - 开篇

“ 随着学习的不断深入和工作经验的积累&#xff0c;欲将之前在博客中整理的Android Graphics知识做进一步整理&#xff0c;并纠正一些理解上的错误&#xff0c;故开设Graphics主题系列文章 ” 序言 由于工作需要&#xff0c;也源于个人兴趣&#xff0c;终于下决心花时间整理一…

Mac 下JDK环境变量配置 及 JDK多版本切换

一、推荐官网下载&#xff1a; 二、环境变量配置 1、查看JDK地址&#xff0c;在终端输入以下命令&#xff1a; /usr/libexec/java_home -V 我的路径&#xff1a; /Library/Java/JavaVirtualMachines/jdk-17.jdk/Contents/Home /Library/Java/JavaVirtualMachines/zulu-11.j…

ffmpeg命令生成器

FFmpeg 快速入门&#xff1a;命令行详解、工具、教程、电子书 – 码中人的博客FFmpeg 是一个强大的命令行工具&#xff0c;可以用来处理音频、视频、字幕等多媒体文件。本文介绍了 FFmpeg 的基本用法、一些常用的命令行参数&#xff0c;以及常用的可视化工具。https://blog.mzh…

nvm安装node后,npm无效

类似报这种问题&#xff0c;是因为去github下载npm时下载失败&#xff0c; Please visit https://github.com/npm/cli/releases/tag/v6.14.17 to download npm. 第一种方法&#xff1a;需要复制这里面的地址爬梯子去下载&#xff08;github有时不用梯子能直接下载&#xff0c;有…

机器学习系列——(二十二)结语

随着我们的机器学习系列的探索画上句号&#xff0c;我们不禁感慨于这一领域的广阔和深邃。从最初的基础概念到复杂的算法&#xff0c;从理论的探讨到实际应用的示例&#xff0c;我们一起经历了一段非凡的旅程。机器学习不仅是当前技术创新的核心驱动力之一&#xff0c;也是塑造…

电脑通电自启动设置

首先要进入BIOS&#xff0c;以华硕为例&#xff0c;按下电源键&#xff0c;在开机之前按下delete键&#xff0c;其他电脑可能是esc或者某个f键&#xff0c;请自行查找。 进入BIOS后要找到电源管理&#xff0c;可以在高级选项中找一找&#xff0c;如上图右下角选择高级模式。 …

基于华为云欧拉操作系统(HCE OS)容器化部署传统应用(Redis+Postgresql+Git+SpringBoot+Nginx)

写在前面 博文内容为 华为云欧拉操作系统入门级开发者认证(HCCDA – Huawei Cloud EulerOS)实验笔记整理认证地址&#xff1a;https://edu.huaweicloud.com/certificationindex/developer/9bf91efb086a448ab4331a2f53a4d3a1博文内容涉及一个传统 Springboot 应用HCE部署&#x…

软件价值7-万花筒

模拟一个万花筒&#xff0c;鼠标点击可以变换图形 import pygame import sys import math import randompygame.init()# 设置窗口大小 WIDTH, HEIGHT 800, 600 CENTER (WIDTH // 2, HEIGHT // 2)# 设置颜色 BLACK (0, 0, 0)# 初始化屏幕 screen pygame.display.set_mode((…

Springboot 整合 Elasticsearch(二):使用HTTP请求来操作ES

&#x1f4c1;前情提要&#xff1a;Springboot整合Elasticsearch&#xff08;一&#xff09;&#xff1a;Linux下安装 Elasticsearch 8.x 目录 一、使用 elasticsearch-head 插件连接 1、下载压缩包 2、在 chrome 浏览器中添加扩展程序 3、修改IP地址&#xff0c;点击连接 …

【GAMES101】Lecture 20 光场

目录 光场&#xff08;Light Field / Lumigraph&#xff09; 广场照相机 光场&#xff08;Light Field / Lumigraph&#xff09; 我们在三维的世界中从一个观测点出发看到这么一幅二维的画面 如果有这么一副画布可以完美的显示出从观察点看到的画面&#xff0c;那用这幅画布…

Java LinkedList 实现栈和队列

Java LinkedList 实现栈和队列 package com.zhong.collection;import java.util.LinkedList;public class LinkedListDemo {public static void main(String[] args) {// LinkedList 创建一个队列LinkedList<String> queue new LinkedList<>();// 进队System.out…

三、设计模式相关理论总结

一、面向对象编程 1.1 概述 简称Object Oriented Program(OOP)&#xff0c;指以类或对象作为基础组织单元&#xff0c;遵循封装、继承、多态以及抽象等特性&#xff0c;进行编程。其中面向对象不一定遵循封装、继承、封装和多态等特性&#xff0c;只是前人总结的套路规范&…

备战蓝桥杯---动态规划之经典背包问题

看题&#xff1a; 我们令f[i][j]为前i个物品放满容量为j的背包的最大价值。 f[i][j]max(f[i-1][j],f[i-1][j-c[i]]w[i]); 我们开始全副成负无穷。f[0][0]0;最后循环最后一行求max; 负无穷&#xff1a;0xc0c0c0c0;正无穷&#xff1a;0x3f3f3f3f 下面是v12,n6的图示&#xff…

TCP的连接和断开详解

目录 1.TCP基础知识 1.1.TCP 头格式 1.2.TCP协议介绍 1.3.UDP协议介绍 1.4.TCP 和 UDP 区别 1.5.TCP 和 UDP 应用场景 1.6.计算机网络相关术语&#xff08;缩写&#xff09; 2.TCP 连接建立&#xff1a;三次握手 2.1.TCP 三次握手过程 2.2.三次握手原理 2.3.异常分析…

我主编的电子技术实验手册(02)——仪表与电源

本专栏是笔者主编教材&#xff08;图0所示&#xff09;的电子版&#xff0c;依托简易的元器件和仪表安排了30多个实验&#xff0c;主要面向经费不太充足的中高职院校。每个实验都安排了必不可少的【预习知识】&#xff0c;精心设计的【实验步骤】&#xff0c;全面丰富的【思考习…

机器学习系列——(二十)密度聚类

引言 在机器学习的无监督学习领域&#xff0c;聚类算法是一种关键的技术&#xff0c;用于发现数据集中的内在结构和模式。与传统的基于距离的聚类方法&#xff08;如K-Means&#xff09;不同&#xff0c;密度聚类关注于数据分布的密度&#xff0c;旨在识别被低密度区域分隔的高…

力扣刷题之旅:进阶篇(六)—— 图论与最短路径问题

力扣&#xff08;LeetCode&#xff09;是一个在线编程平台&#xff0c;主要用于帮助程序员提升算法和数据结构方面的能力。以下是一些力扣上的入门题目&#xff0c;以及它们的解题代码。 --点击进入刷题地址 引言 在算法的广阔天地中&#xff0c;图论是一个非常重要的领域。…

林浩然与杨凌芸的Java异常处理大冒险

林浩然与杨凌芸的Java异常处理大冒险 Lin Haoran and Yang Lingyun’s Java Exception Handling Adventure 在一个阳光明媚的午后&#xff0c;编程世界的英雄——林浩然和杨凌芸坐在Java王国的咖啡馆里&#xff0c;一边品尝着香醇的代码咖啡&#xff0c;一边探讨着他们的最新挑…

Excel——高级筛选匹配条件提取数据

一、筛选多条件 Q&#xff1a;筛选多个条件&#xff0c;并将筛选出的内容复制到其他区域 点击任意一个单元格 点击【数据】——【筛选】——【高级筛选】 选择【将筛选结果复制到其他位置】——在【列表区域】 鼠标选择对应的区域位置&#xff0c;条件区域一定要单独写出来&a…