JVM频繁FullGC:面试通关“三部曲”心法
想象一下,你的Java应用程序是一个繁忙的工厂,JVM堆内存就是工厂的仓库和车间。垃圾收集(GC)就像工厂的清洁工,负责清理不再需要的废料(无用对象),腾出空间让新的生产(对象分配)继续。Minor GC(年轻代GC)像是日常小范围清洁,速度快,影响小。而Full GC(完全垃圾收集,通常涉及老年代和整个堆)则是一次彻底的、停工级别的大扫除,耗时长,会导致工厂所有生产线(应用线程)暂停(Stop-The-World, STW)。
如果你的工厂频繁地进行这种“停工大扫除”,那问题就大了!这意味着:
- 生产效率低下(应用响应缓慢,吞吐量下降)。
- 工人(用户)抱怨连连(用户体验差)。
- 甚至可能因为长时间停工而导致订单积压、系统崩溃。
作为“工厂总调度”,当发现Full GC过于频繁时,你的首要任务不是去研究每一块废料的成分,而是立即采取措施,减少“停工”的频率和时长,让工厂先恢复基本的生产效率!
“停工警报”:频繁Full GC的线上应急三板斧 (事中应急处理 - 核心要务!)
当监控告警显示Full GC次数异常增多、GC耗时过长,或者应用出现周期性卡顿、响应时间飙升时,你必须火速行动。
-
板斧一:火眼金睛,确认“大扫除”的模式与影响!
-
监控系统是你的“生产看板”和“告警灯”:
- GC日志分析工具(如GCViewer, GCeasy)或APM的GC监控: Full GC发生的频率有多高(比如几分钟一次,甚至几十秒一次)?每次Full GC耗时多长(几百毫秒还是几秒甚至更长)?Full GC前后老年代(Old Gen)的内存占用率变化如何(如果GC后老年代依然很高,说明问题严重)?年轻代(Young Gen)晋升到老年代的对象数量和速率如何?
- JVM监控(JConsole, VisualVM, Arthas dashboard): 实时观察堆内存(特别是老年代)的使用趋势,是否在Full GC后快速回升到高水位?CPU使用率在Full GC期间是否飙升(GC线程占用CPU)?应用线程是否大量暂停?
- 应用性能指标: 接口响应时间、吞吐量(QPS/TPS)、错误率是否在Full GC期间或之后出现明显恶化?
-
关联近期“生产调整”:
- 最近有代码上线吗? (特别是涉及大量对象创建、集合操作、缓存处理、长生命周期对象管理的代码,这是头号嫌疑!)
- JVM参数是否有变更?(比如堆大小、GC收集器、年轻代/老年代比例等)
- 业务流量或数据处理量是否有突增?(比如某个新功能上线导致对象创建速率远超预期)
- 依赖的外部系统(如数据库返回大量数据)是否导致应用内存压力增大?
-
-
板斧二:紧急“调度”,减少“停工”损失!
-
目标: 尽快降低Full GC的频率和单次耗时,或者减轻其对应用性能的影响。
-
行动1:重启“问题生产线”旁的应用实例 (谨慎使用,作为最后手段之一)!
-
如果某个或某几个应用实例的Full GC情况远比其他实例严重(可能是该实例遇到了特定的数据或请求导致内存异常),并且这些实例是无状态的或重启影响可控,可以考虑重启这些问题实例。重启能清空内存,临时消除当前的GC压力。
-
⚠️ 注意: 这只是“扬汤止沸”,不能解决根本问题。重启前务必抢救诊断信息:
-
Heap Dump (堆转储/堆快照):
-
自动获取: JVM参数配置 -XX:+HeapDumpOnOutOfMemoryError -XX:HeapDumpPath=/path/to/heapdump/java_pid<pid>.hprof。发生OOM时会自动生成。
-
手动获取 (若应用假死但未OOM):
- jmap -dump:format=b,file=heap.hprof <pid> (注意:jmap可能导致应用长时间暂停,线上慎用或在摘除流量后使用)
- jcmd <pid> GC.heap_dump /path/to/dump.hprof (推荐,对应用影响较小)
-
-
GC日志:
- 确保已开启: JVM参数配置 -Xloggc:/path/to/gclog/gc.log -XX:+PrintGCDetails -XX:+PrintGCDateStamps -XX:+PrintHeapAtGC (Java 8及以前) 或使用Java 9+的统一日志框架 -Xlog:gc*:file=/path/to/gclog/gc.log:time,level,tags:filecount=5,filesize=50m。
- GC日志是分析GC行为、频率、耗时的关键。
-
-
-
行动2:紧急“版本回滚” (如果高度怀疑是新代码的锅)!
- 如果有充分证据(比如Full GC问题紧随某次上线后爆发)表明是近期代码变更引入的问题(如内存泄漏、对象创建过多),并且有成熟的回滚方案,立即执行版本回滚。
-
行动3:服务降级/限流,减轻“生产压力”!
- 如果频繁Full GC是由某些特定的、消耗内存巨大的非核心功能触发的(比如一个复杂的、需要加载大量数据的报表功能,或者一个用户上传大文件的处理逻辑),可以考虑临时通过配置开关关闭或降级这个功能。
- 如果是整体流量过大导致内存压力持续在高位,可以在应用入口层进行限流,减少请求处理量,给GC更多喘息空间。
-
行动4:临时调整JVM参数 (非常谨慎!治标不治本,可能引入新问题)!
- 临时增加堆内存 (-Xmx): 如果判断是短期内业务量确实暴增,超出了当前堆大小的承载能力,且服务器物理内存充足,可以考虑临时小幅增加最大堆内存。但这可能会导致单次Full GC时间更长。
- 调整GC策略或参数(高风险,需专家评估): 比如临时调整年轻代与老年代的比例、尝试切换到其他GC收集器(如果当前收集器明显不适应场景且有备选方案),或者微调某些GC参数(如 -XX:SurvivorRatio, -XX:NewRatio, -XX:MaxTenuringThreshold)。这些操作风险极高,通常需要资深工程师或JVM专家评估,不应轻易尝试。
-
行动5:DBA或下游服务协助 (如果压力来自外部):
- 如果应用内存压力是因为从数据库一次性查询了过多数据,或者下游服务返回了超大对象,请求DBA或下游服务团队协助优化数据返回量或进行限流。
-
-
板斧三:全员戒备,信息同步!
- 立即将故障情况、影响范围、已采取的应急措施、初步判断等信息同步给团队(开发、运维/SRE)、上级以及DBA、业务方。请求相关方协助排查。
“事中应急”的核心:不是让你当场变成GC调优大师,而是要你利用监控和运维手段,快速判断GC问题的严重程度和可能诱因,采取最直接有效的措施(回滚、降级、限流、重启、保留现场)来缓解系统压力,恢复应用的基本性能,同时有强烈的意识去保全用于事后分析的关键诊断信息(GC日志、Heap Dump)。
“仓库大检查”:找出“垃圾”为何堆积如山 (诊断与根因分析)
当线上系统的“停工大扫除”频率通过应急手段得到初步控制后(比如Full GC不再那么密集,应用响应有所改善),现在才是仔细调查“为什么仓库总是这么快就满了”的时候。
-
最重要的线索:GC日志深度分析
-
使用专业的GC日志分析工具(如GCViewer, GCeasy, GCHisto)或APM平台的GC分析模块,对收集到的GC日志进行详细解读。
-
关注核心指标:
- GC类型和频率: Minor GC和Full GC的发生频率,Full GC是否过于频繁?
- GC耗时与STW时间: 每次GC(特别是Full GC)的耗时多长?应用暂停(Stop-The-World)时间多长?
- 各内存区域变化: Young Gen(Eden, Survivor)、Old Gen、Metaspace在GC前后的内存占用变化。Old Gen是否在Full GC后依然很高,或者很快再次填满?
- 对象晋升情况: 有多少对象从Young Gen晋升到Old Gen?晋升速率是否过快?MaxTenuringThreshold(对象晋升老年代的年龄阈值)设置是否合理?
- 是否存在大量的晚期分配失败(Promotion Failure)或并发模式失败(Concurrent Mode Failure,针对CMS或G1)?
- 分配速率(Allocation Rate): 应用创建对象的速率有多快?
-
-
铁证如山:Heap Dump (堆转储文件) 分析
-
使用专业的内存分析工具,如 Eclipse Memory Analyzer Tool (MAT) 或 JVisualVM(其Heap Walker功能)。
-
分析重点:
-
查找大对象消耗者 (Dominator Tree & Histogram):
- 哪些类的实例占用了最多的堆内存?(Histogram视图)
- 哪些对象是“支配者”(Dominator),即如果它们被回收,将释放大量内存?(Dominator Tree视图)
- 这些大对象是什么?是巨大的集合(ArrayList, HashMap)、byte[]、String,还是自定义的业务对象?
-
定位内存泄漏疑点 (Leak Suspects Report): MAT的泄漏疑点报告能自动分析并给出可能的内存泄漏源头和累积点。
-
分析GC Roots引用链: 对于可疑的大对象或泄漏对象,追溯其到GC Roots的引用链,理解它们为什么不能被垃圾回收器回收。是被静态变量持有?被活动的线程持有?还是被JNI本地代码引用?
-
示例场景(来自您提供的资料): MAT分析发现大量的 com.example.Order 对象占用了老年代大部分空间,这些对象中包含了大量历史订单数据,并且被一个静态的 recentOrders 集合持有而没有及时清理。
-
-
-
代码审查:“垃圾制造工厂”探秘
-
根据GC日志和Heap Dump的分析结果,重点审查相关的代码模块:
- 对象创建热点: 哪些代码路径在大量创建对象?创建的是否都是必要的?有没有可以复用或减少创建的可能?
- 长生命周期对象: 是否存在不必要的长生命周期对象(如静态集合、单例中持有的集合)持续累积数据而没有清理机制?
- 大对象分配: 是否在代码中一次性创建了非常大的对象(如读取整个大文件到内存、查询数据库返回了过多结果集并全部加载到List中)?
- 资源未关闭: 虽然主要导致堆外内存或句柄泄漏,但某些情况下也可能间接影响堆内存(比如持有的对象无法释放)。
- 不当的缓存使用: 缓存没有设置合理的过期策略或大小限制,导致缓存对象无限增长。
- ThreadLocal使用不当: 在线程池中使用ThreadLocal,如果线程复用而ThreadLocal变量没有在使用后及时remove(),可能导致对象无法回收。
- Finalizer滥用: finalize()方法执行缓慢或阻塞,可能导致对象延迟回收。
-
-
JVM参数配置检查:
- 堆大小设置 (-Xms, -Xmx): 是否过小,不足以容纳应用正常运行所需的存活对象?或者设置过大,导致单次Full GC时间过长?
- 年轻代/老年代比例 (-XX:NewRatio, -XX:SurvivorRatio): 是否合理?不合理的比例可能导致对象过早或过晚进入老年代。
- Metaspace大小 (-XX:MetaspaceSize, -XX:MaxMetaspaceSize): 如果是Metaspace OOM或频繁Full GC与Metaspace回收有关,检查其大小配置。
- GC收集器选择与配置: 当前使用的GC收集器(Serial, Parallel, CMS, G1, ZGC, Shenandoah)是否适合应用的场景和负载特性?其相关参数配置是否最优?
“工厂改造”与“生产流程优化” (事后修复与预防)
找到频繁“大扫除”的根源后,就要进行彻底的“工厂改造”和“流程优化”,确保生产高效、垃圾减量。
-
“源头减量”与“废物回收” (代码优化):
- 修复内存泄漏: 这是最根本的。确保不再需要的对象能够被GC及时回收(断开不必要的强引用、正确关闭资源、清理集合和缓存、正确使用ThreadLocal等)。
- 优化对象创建: 避免不必要的对象创建,复用对象,使用对象池(如果适用)。
- 处理大对象: 避免一次性加载或创建超大对象。采用流式处理、分批处理、延迟加载等技术。
- 优化数据结构: 选择更节省内存的数据结构。
- 合理设计缓存: 设置明确的缓存大小上限和淘汰策略(如LRU, LFU, TTL)。
- 示例修复(来自您提供的资料): 对静态的 recentOrders 队列设置了最大容量限制,并在添加新订单时,如果超出容量则移除最旧的订单。
-
“清洁设备升级”与“排班优化” (JVM参数调优):
-
科学调整堆大小: 根据应用的实际内存占用(峰值、谷值、对象生命周期分布)和服务器物理内存,合理设置 -Xms 和 -Xmx。
-
优化年轻代与老年代比例和大小: 目标是让大部分朝生夕死的对象在Young GC中就被回收,减少进入老年代的对象数量。
-
选择合适的GC收集器:
- 对于高吞吐量、可接受一定STW的应用,可考虑Parallel GC。
- 对于要求低延迟、STW时间尽可能短的应用,可考虑CMS、G1、ZGC、Shenandoah(根据JDK版本和硬件支持)。
-
针对所选GC收集器进行参数微调: 例如,G1的 -XX:MaxGCPauseMillis(期望最大GC暂停时间)、-XX:InitiatingHeapOccupancyPercent(触发并发标记周期的堆占用百分比)等。
-
这是一个迭代和实验的过程,没有万能的参数配置,需要结合具体应用和负载进行测试和调整。
-
-
加强“车间监控”与“预警系统” (监控与告警):
- 对JVM的堆内存各区域使用率、GC次数和耗时(区分Minor GC和Full GC)、对象分配速率、线程数等关键指标进行持续、细致的监控。
- 设置科学的告警阈值,在内存使用出现异常趋势、GC压力增大时能提前预警,而不是等到OOM或系统卡死才发现。
-
进行“生产演练”与“工人培训” (测试与规范):
- 在上线前,对应用进行充分的压力测试和长时间的稳定性测试,观察在高负载和长时间运行下的内存和GC表现。
- 制定关于内存使用、对象创建、资源管理的代码规范和最佳实践。
- 在Code Review中重点关注可能导致内存问题或GC压力的代码。
- 组织团队进行JVM内存管理、GC原理、性能分析工具使用的培训。
核心思想:线上频繁Full GC应急,首要是通过回滚、降级、重启等手段快速恢复系统性能,并务必保留GC日志和Heap Dump。事后通过专业工具深入分析这些诊断信息,定位是内存泄漏、对象创建过多还是JVM配置不当等根本原因,最终通过代码优化、JVM调优和加强监控来彻底解决并预防问题,让“工厂”高效运转,告别频繁“停工大扫除”。
相关文章:
JVM频繁FullGC:面试通关“三部曲”心法
想象一下,你的Java应用程序是一个繁忙的工厂,JVM堆内存就是工厂的仓库和车间。垃圾收集(GC)就像工厂的清洁工,负责清理不再需要的废料(无用对象),腾出空间让新的生产(对象…...
Scala语言基础与函数式编程详解
Scala语言基础与函数式编程详解 本文系统梳理Scala语言基础、函数式编程核心、集合与迭代器、模式匹配、隐式机制、泛型与Spark实战,并对每个重要专业术语进行简明解释,配合实用记忆口诀与典型代码片段,助你高效学习和应用Scala。 目录 Scal…...
大语言模型 13 - 从0开始训练GPT 0.25B参数量 MiniMind2 补充 训练开销 训练步骤 知识蒸馏 LoRA等
写在前面 GPT(Generative Pre-trained Transformer)是目前最广泛应用的大语言模型架构之一,其强大的自然语言理解与生成能力背后,是一个庞大而精细的训练流程。本文将从宏观到微观,系统讲解GPT的训练过程,…...
【NLP】37. NLP中的众包
众包的智慧:当“无数人”帮你训练AI 当我们谈论构建大语言模型时,脑海中浮现的往往是服务器、GPU 和Transformer,而很少想到成千上万的普通人也在默默贡献力量。 这背后依赖的机制就是:众包(Crowdsourcing࿰…...
数据分析入门指南:从历史到实践
在信息爆炸的时代,数据分析已经成为各行各业不可或缺的技能,无论是商业决策、医疗研究,还是社会科学,数据分析都在其中扮演着关键角色。本文将带你深入了解数据分析的历史、定义、流程、数据来源与处理、常用工具,并通…...
大语言模型 12 - 从0开始训练GPT 0.25B参数量 MiniMind2 补充 训练开销 训练步骤 知识蒸馏 LoRA等
写在前面 GPT(Generative Pre-trained Transformer)是目前最广泛应用的大语言模型架构之一,其强大的自然语言理解与生成能力背后,是一个庞大而精细的训练流程。本文将从宏观到微观,系统讲解GPT的训练过程,…...
精益数据分析(68/126):数据透视表实战与解决方案验证——从问卷分析到产品落地的关键跨越
精益数据分析(68/126):数据透视表实战与解决方案验证——从问卷分析到产品落地的关键跨越 在创业的移情阶段,通过问卷调查获取数据后,如何深入分析数据并验证解决方案的可行性?今天,我们结合《…...
Cursor 模型深度分析:区别、优缺点及适用场景
Cursor 模型深度分析:区别、优缺点及适用场景 在AI辅助编程领域,Cursor凭借其多模型架构和智能上下文感知能力,成为开发者提升效率的核心工具。不同模型在代码生成、逻辑推理、多模态处理等方面存在显著差异,本文将结合技术特性与…...
LightRAG 由入门到精通
LightRAG 由入门到精通 作者:王珂 邮箱:49186456qq.com 文章目录 LightRAG 由入门到精通简介一、LightRAG Server1.1 安装 LightRAG Server1.2 LightRAG Server 和 WebUI1.2.1 配置 LightRAG Server1.2.2 启动 LightRAG Server1.2.3 使用 Docker 加载 …...
【Spring Boot 整合 MongoDB 完整指南】
目录 Spring Boot 整合 MongoDB 完整指南1. 添加依赖2. 配置 MongoDB 连接application.properties 方式:application.yml 方式:3. 创建实体类(映射MongoDB中的文档,相当于MySQL的表)4. 创建 Repository 接口完成简单操作5. 使用 MongoTemplate 进行复杂操作6. 高级配置配置…...
prisma连接非关系型数据库mongodb并简单使用
prisma连接非关系型数据库如mongodb数据库并简单使用 安装 mongodbPrisma连接mongodb改造目录结构写一个model增查查多个查单个分页排序改改多个删单个多个最后代码进度安装 mongodb 社区版下载 副本集模式文档 可以百度下安装副本集模式,因为prisma要用事务。 如果你觉得安装…...
深度强化学习 | 基于SAC算法的移动机器人路径跟踪(附Pytorch实现)
目录 0 专栏介绍1 软性演员-评论家SAC算法2 基于SAC算法的路径跟踪2.1 SAC网络设计2.2 动作空间设计2.3 奖励函数设计 3 算法仿真 0 专栏介绍 本专栏以贝尔曼最优方程等数学原理为根基,结合PyTorch框架逐层拆解DRL的核心算法(如DQN、PPO、SAC)逻辑。针对机器人运动…...
VS中将控制台项目编程改为WINDOWS桌面程序
有时候因为误操作,建立了控制台项目,但是实际上想建立桌面程序。那么应该如何改过来呢? 一共要修改两个地方,修改步骤如下: 第一处修改地点: 将C/C下面的预处理器选项中,将原本的_CONSOLE修改…...
从API到UI:直播美颜SDK中的滤镜与贴纸功能开发与落地方案详解
时下,滤镜和贴纸功能,已经成为主播们展现个性、增强互动的“必备神器”。那么,这些功能背后的技术实现到底有多复杂?如何从API到UI构建一个流畅、灵活的美颜SDK呢?本文将从底层原理到前端实现,全面解析这两…...
vue3与springboot交互-前后分离【验证element-ui输入的内容】
系列文章目录 提示:帮帮志会陆续更新非常多的IT技术知识,希望分享的内容对您有用。本章分享的是node.js和vue的使用。前后每一小节的内容是存在的有:学习and理解的关联性。【帮帮志系列文章】:每个知识点,都是写出代码…...
VS2017编译librdkafka 2.1.0
VS2017编译librdkafka 2.1.0 本篇是 Windows系统编译Qt使用的kafka(librdkafka)系列中的其中一篇,编译librdkafka整体步骤大家可以参考: Windows系统编译Qt使用的kafka(librdkafka) 由于项目需要,使用kafka,故自己编译了一次,编译的过程,踩了太多的坑了,特写了本篇…...
DeepSeek 赋能数字孪生:重构虚实共生的智能未来图景
目录 一、数字孪生技术概述1.1 数字孪生的概念1.2 技术原理剖析1.3 应用领域与价值 二、DeepSeek 技术解读2.1 DeepSeek 的技术亮点2.2 与其他模型的对比优势 三、DeepSeek 赋能数字孪生3.1 高精度建模助力3.2 实时数据处理与分析3.3 智能分析与预测 四、实际案例解析4.1 垃圾焚…...
谷歌前CEO TED演讲解析:AI 红利的三年窗口期与行业重构
谷歌前CEO埃里克施密特在2025年TED演讲中提出的"AI红利仅剩3年窗口期"观点,揭示了AI技术从算力、需求到监管的全局性变革。以下是基于演讲内容及关联数据的深度分析: 谷歌前CEO TED演讲解析:AI红利的三年窗口期与行业重构 一、算…...
数据仓库面试题合集②】ETL 设计与调度策略详解
📌 面试官为什么爱问 ETL 与调度? ETL 与调度是数据链路的“输血管道”,它的设计直接决定了数据处理的稳定性、扩展性与时效性。面试中此类问题侧重考察: 数据流设计是否合理 对任务依赖与失败容错的认知 是否具备复杂调度 DAG 设计经验 是否理解增量/全量策略、分区机制…...
前端入职总结
负责的工作内容,遇到的问题,怎么解决, 技能组溢出 问题一:溢入溢出bug 互斥实现的核心逻辑 状态管理: selectedOverflowGroups:存储当前选中的溢出技能组ID(数字字符串数组) sel…...
易境通海外仓系统:一件代发全场景数字化解决方案
随着全球经济一体化和消费升级,一件代发业务的跨境电商市场规模持续增长。然而,一件代发的跨境运营也面临挑战,传统海外仓管理模式更因效率低下、协同困难成为业务扩张的瓶颈。 一、一件代发跨境运营痛点 1、多平台协同:卖家往往…...
C#接口的setter或getter的访问性限制
有时候只想对外提供getter,但是属性的赋值又必须是setter,此时,可以限制setter的访问性。例如,假设有一个自定义字典(MyDict)属性,该属性我只希望外部能够访问,但是设置必须在内部,则可提供如下…...
云计算与大数据进阶 | 26、解锁云架构核心:深度解析可扩展数据库的5大策略与挑战(下)
在数据库的世界里,面对数据如潮水般的增长难题,聪明的工程师早已准备了五大扩展方案来应对,它们就像五把钥匙,以破解着不同场景下的性能困局。 上回书云计算与大数据进阶 | 26、解锁云架构核心:深度解析可扩展数据库的…...
SID 2025上的天马,用“好屏”技术重构产业叙事
作为全球最具影响力的显示行业盛会,SID国际显示周不仅是技术比拼的舞台,更是未来产业方向的风向标。SID 2025上的技术密度与产业动态,再一次验证了这一定律。 Micro-LED、柔性OLED、裸眼3D、量子点、透明显示等新技术在SID 2025集中亮相&…...
深入理解 Hadoop 核心组件 Yarn:架构、配置与实战
一、Hadoop 三大件概述 Hadoop 作为大数据领域的基石,其核心由三大组件构成: HDFS(分布式文件系统):负责海量数据的分布式存储,通过数据分块和副本机制保障可靠性,是大数据存储的基础设施。 …...
Linux云计算训练营笔记day11(Linux CentOS7)
Linux云计算 云计算是一种服务,是通过互联网按需提供计算资源的服务模式 程序员写代码的,部署上线项目 买服务器(一台24小时不关机的电脑,为客户端提供服务) 20万 买更多的服务器 Linux(命令) windows(图形化) 就业岗位: 云计算工程师 li…...
2025年AI与网络安全的终极博弈:冲击、重构与生存法则
引言 2025年,生成式AI的推理速度突破每秒千万次,网络安全行业正经历前所未有的范式革命。攻击者用AI批量生成恶意代码,防御者用AI构建智能护盾,这场技术军备竞赛正重塑行业规则——60%的传统安全岗位面临转型,70%的防…...
Hadoop中 8020、9000、50070 端口用途的详细对比
Hadoop 端口用途对比教程 1. 端口用途总览 Hadoop 的核心服务(如 NameNode、DataNode、ResourceManager 等)通过不同的端口对外提供服务。不同版本中,部分端口号可能发生变化,尤其是 Hadoop 3.x 对部分默认端口进行了调整。 端口Hadoop 2.x (2.7.7)Hadoop 3.x (3.1.3)协议…...
HLS学习
文章目录 前言一、hls是什么二、m3u8文件格式说明 前言 在工作,需要跟m3u8的格式进行打交道,所以就去学习了一些相关的内容。本文是相关的笔记。 一、hls是什么 HTTP Live Streaming,缩写为HLS,是由苹果公司提出基于HTTP的流媒体…...
【Linux系统】Linux入门系统程序−进度条
文章目录 一、铺垫知识1.回车符 和 换行符的区别2.用户缓冲区问题 二、进度条程序初版(含视频演示效果)三、进度条程序(加入使用场景) 一、铺垫知识 1.回车符 和 换行符的区别 回车符’\r’ 的效果(让光标回到当前行开头) 和 换…...
Java大师成长计划之第27天:RESTful API设计与实现
📢 友情提示: 本文由银河易创AI(https://ai.eaigx.com)平台gpt-4-turbo模型辅助创作完成,旨在提供灵感参考与技术分享,文中关键数据、代码与结论建议通过官方渠道验证。 在现代软件架构中,RESTf…...
SEO长尾词与关键词优化策略
内容概要 在搜索引擎优化(SEO)实践中,长尾关键词与核心关键词的协同布局是提升网站可见性与流量的核心路径。本文系统性阐述从基础策略到高阶技术的全链路优化方案,重点剖析长尾关键词的挖掘逻辑与筛选标准,建立基于搜…...
Linux-进程信号
1.快速认识信号 1.1生活角度的信号 你在⽹上买了很多件商品,再等待不同商品快递的到来。但即便快递没有到来,你也知道快递来临 时,你该怎么处理快递。也就是你能“识别快递” 当快递员到了你楼下,你也收到快递到来的通知&#…...
Trae生成 django5.2.1后台管理
安装django,采用的是5.2.1版本: pip install django Trae对话框中输入: 基于django框架,生成版本管理功能,版本管理模块命名为versions,工程项目命名为main 迁移数据库: python manage.py …...
Interrupt 2025 大会回顾:关于LangChain 的 AI Agent会议内容总结
Interrupt 2025 大会已圆满落下帷幕!今年,来自全球各地的 800 多位人士齐聚旧金山,参加了 LangChain 首次举办的行业盛会,共同聆听各团队分享构建 AI Agent 的经验故事——会议的精彩和余温至今仍令人振奋! 思科、优步…...
C#学习9——接口、抽象类
一、接口 1.什么是接口 官方话:是一种定义契约(一组方法、属性、事件或索引器的抽象声明)的机制,它规定了实现该接口的类或结构必须提供这些成员的具体实现。接口是面向对象编程中实现多态和抽象的重要工具。 个人理解…...
【高德开放平台-注册安全分析报告】
前言 由于网站注册入口容易被黑客攻击,存在如下安全问题: 暴力破解密码,造成用户信息泄露短信盗刷的安全问题,影响业务及导致用户投诉带来经济损失,尤其是后付费客户,风险巨大,造成亏损无底洞…...
Xshell实战:远程连接VMware CentOS7虚拟机与高效运维指南——从零配置到自动化操作,解锁Xshell的核心价值
一、实战背景与目标 在开发与运维工作中,常需通过本地Windows主机远程管理虚拟机中的Linux系统。Xshell作为专业终端工具,能快速建立安全连接,执行高效操作。 场景需求: 在Windows系统中,通过Xshell远程连接VMware中的…...
C#编写软件添加菜单栏
将MenuStrip控件拖动到窗体,可以直接在工具箱搜索menu,我是先在窗体上上加了一个panel,把MenuStrip拖动到panel上面,点击即可输入自己需要的文本。...
【C++】map和multimap的常用接口详解
map和multimap的文档:<map> - C Reference 1.map类的介绍 map 有两个模板参数,是 key/value的场景。 这里的Key就是key,T就是value,命名不同而已。map默认要求Key⽀持⼩于⽐较(升序),如…...
线程池模式与C#中用法
一、线程池模式解析 1. 核心概念 线程池是一种 管理线程生命周期的技术,主要解决以下问题: 减少线程创建/销毁开销:复用已存在的线程 控制并发度:避免无限制创建线程导致资源耗尽 任务队列:有序处理异步请求 2. …...
47、C#可否对内存进⾏直接的操作?
是的,C# 可以通过几种方式对内存进行直接操作,尽管它主要是一门托管语言,内存管理通常由.NET运行时自动处理。 主要方法 1.unsafe 代码和指针 使用 unsafe 关键字可以启用指针操作需要项目启用"允许不安全代码"选项示例…...
精益数据分析(70/126):MVP迭代中的数据驱动决策与功能取舍
精益数据分析(70/126):MVP迭代中的数据驱动决策与功能取舍 在创业过程中,最小可行化产品(MVP)的迭代优化是从验证假设到实现产品市场契合的关键环节。今天,我们结合《精益数据分析》中的方法论…...
大数据与数据库服务器参数调优方法
1 硬件配置优化 存储与磁盘 优先选择 SSD固态硬盘替代机械硬盘,显著降低I/O延迟,提升随机读写性能。 采用 RAID 10阵列实现高性能与冗余的平衡,适用于高并发数据库场景。 大数据场景中,通过多磁盘并行挂载(如HDFS)提升吞吐量,规避单盘性能瓶颈。 I/…...
【Fifty Project - D28】
今日完成记录 TimePlan完成情况9:30 - 11:30Leetcode√14:00 - 15:30练胸√15:30 - 16:30Leetcode√19:40 - 21:20有氧√ Leetcode 今天是周赛复盘篇,昨天的周赛太刺激…...
Image and depth from a conventional camera with a coded aperture论文阅读
Image and depth from a conventional camera with a coded aperture 1. 研究目标与实际意义1.1 研究目标1.2 实际问题与产业意义2. 创新方法:编码光圈设计与统计模型2.1 核心思路2.2 关键公式与模型架构2.2.1 图像形成模型2.2.2 深度可区分性准则2.2.3 统计模型与优化框架2.2…...
vue3 vite 项目中自动导入图片
vue3 vite 项目中自动导入图片 安装插件配置插件使用方法 安装插件 yarn add vite-plugin-vue-images -D 或者 npm install vite-plugin-vue-images -D配置插件 在 vite.config.js 文件中配置插件 // 引入 import ViteImages from vite-plugin-vue-images;plugins: [vue(),/…...
软考-软件工程开发模型
软考-软件工程开发模型 参考视频: 软件工程概述&开发模型 ,配合视频理解更清晰~ 软件的生命周期为:需求分析、软件设计、软件开发、运行维护直至被淘汰 几个阶段。 软件工程支持 4 个活动,简称 PDCA,…...
纸上流年:Linux基础IO的文件理解与操作
文章目录 前言:数字世界的窗口🌇序章🏙️正文一、文件理解二、C语言文件操作2.1、文件打开2.2、文件关闭2.3、文件写入2.4、文件读取 三、系统级文件操作3.1、打开 open3.1.1、函数理解 3.2、关闭 close3.3、写入 write3.4、读取 read 四、小…...
基础深度补全模型DepthLab: From Partial to Complete
许多任务本身就包含部分深度信息,例如:(1)三维高斯图像修复;(2)激光雷达深度补全;(3)利用 Dust3R 进行稀疏视角重建;以及(4࿰…...