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

【Linux 内核 | 操作系统 | 内核编译】内核编译中与锁调试相关的设置有哪一些?内核 Debug 选项中 LockDep 和其他锁调试选项详解

​问题描述:

我在看内核锁调试的信息时,看到了一些内核编译参数相关的设置,开启这些信息可以帮助我们在测试环境中调试锁的竞争情况,可以详细的打印出来一些线程持有锁,一些线程争抢锁的信息。

以下是我的配置:【部分配置】

CONFIG_LOCK_DEBUGGING_SUPPORT=y
# CONFIG_PROVE_LOCKING is not set
# CONFIG_LOCK_STAT is not set
# CONFIG_DEBUG_RT_MUTEXES is not set
# CONFIG_DEBUG_SPINLOCK is not set
# CONFIG_DEBUG_MUTEXES is not set
# CONFIG_DEBUG_WW_MUTEX_SLOWPATH is not set
# CONFIG_DEBUG_RWSEMS is not set
# CONFIG_DEBUG_LOCK_ALLOC is not set 

问题讲解:

1.基础锁调试支持

bash

CONFIG_LOCK_DEBUGGING_SUPPORT=y
  • 作用:启用锁调试的基础框架,但不直接提供具体调试功能,需要依赖其他子选项。
  • 影响:这是锁调试的“总开关”,但需要配合其他子选项(如CONFIG_PROVE_LOCKINGCONFIG_LOCK_STAT)才能发挥实际作用。

2. 关键未启用的调试选项

a. 锁依赖验证(Lock Dependency Validator)

bash

# CONFIG_PROVE_LOCKING is not set
  • 作用:检测潜在的锁顺序错误死锁风险,通过静态分析锁的获取顺序。
  • 未启用的后果:内核无法在运行时发现锁的非法使用顺序(如可能引发死锁的锁获取路径)。
b. 锁竞争统计

bash

# CONFIG_LOCK_STAT is not set
  • 作用:记录每个锁的竞争次数等待时间等统计信息,通过/proc/lock_stat可查看。
  • 未启用的后果:无法直接定位高竞争锁,难以量化锁的性能瓶颈。
c. 特定锁类型的调试

bash

# CONFIG_DEBUG_RT_MUTEXES is not set      # 实时互斥锁(RT Mutex)调试
# CONFIG_DEBUG_SPINLOCK is not set        # 自旋锁调试
# CONFIG_DEBUG_MUTEXES is not set         # 互斥锁调试
# CONFIG_DEBUG_WW_MUTEX_SLOWPATH is not set  # 等待-死亡互斥锁调试
# CONFIG_DEBUG_RWSEMS is not set          # 读写信号量调试
  • 作用:针对特定锁类型的详细调试(如检测错误释放、重复加锁等)。
  • 未启用的后果:无法捕获特定锁类型的低级错误(如释放未持有的锁)。
d. 锁分配追踪

bash

# CONFIG_DEBUG_LOCK_ALLOC is not set
  • 作用:追踪锁的初始化和内存分配,辅助发现锁未初始化或重复初始化问题。
  • 未启用的后果:难以调试因锁未正确初始化导致的崩溃或竞争。

3. 当前配置的局限性

  • 锁竞争分析能力
    由于CONFIG_LOCK_STAT未启用,无法通过/proc/lock_stat获取锁的竞争统计信息,难以定位高竞争锁。

  • 死锁风险检测
    CONFIG_PROVE_LOCKING未启用,内核无法主动检测锁顺序错误,可能遗留潜在的死锁隐患。

  • 低级锁错误检测
    特定锁类型的调试选项(如CONFIG_DEBUG_SPINLOCK)未启用,无法捕获锁的非法操作(如错误释放)。


4. 改进建议

a. 启用关键调试选项(测试环境推荐)​

bash

CONFIG_PROVE_LOCKING=y       # 启用锁依赖验证
CONFIG_LOCK_STAT=y           # 启用锁竞争统计
CONFIG_DEBUG_LOCK_ALLOC=y    # 启用锁分配追踪
  • 操作方式:通过make menuconfig → ​Kernel Hacking → Lock Debugging 启用。
b. 针对性调试选项(按需启用)​

bash

CONFIG_DEBUG_SPINLOCK=y      # 调试自旋锁(常见于多核竞争场景)
CONFIG_DEBUG_MUTEXES=y       # 调试互斥锁(常见于睡眠锁问题)
c. 运行时验证

启用上述选项后,结合工具进一步分析:

  • 锁统计:通过/proc/lock_stat查看竞争热点。
  • 死锁检测CONFIG_PROVE_LOCKING会主动报告锁顺序问题。
  • ftrace/perf:跟踪锁竞争事件(即使不启用CONFIG_LOCK_STAT,但精度较低)。

5. 性能权衡

  • 调试开销
    CONFIG_PROVE_LOCKINGCONFIG_LOCK_STAT会引入性能损耗(尤其是高锁竞争场景),建议仅在测试环境启用。

  • 生产环境
    若需在生产环境调试,可选择性启用CONFIG_LOCK_STAT,但需评估对系统吞吐量的影响。

相关文章:

【Linux 内核 | 操作系统 | 内核编译】内核编译中与锁调试相关的设置有哪一些?内核 Debug 选项中 LockDep 和其他锁调试选项详解

​问题描述: 我在看内核锁调试的信息时,看到了一些内核编译参数相关的设置,开启这些信息可以帮助我们在测试环境中调试锁的竞争情况,可以详细的打印出来一些线程持有锁,一些线程争抢锁的信息。 以下是我的配置&#…...

LinuX---Shell---变量

系统预定义变量 常用系统变量 PATH、HOME、PWD、SHELL、USER等 获取变量的值 语法:$变量名 $和变量名之间不能有空格。 案例实操 查看系统变量的值 fengubuntu:~$ echo $PATH /usr/local/sbin:/usr/local/bin:/usr/sbin:/usr/bin:/sbin:/bin:/usr/games:/u…...

深入理解Spring MVC:构建灵活的Web应用

大家好!今天我们来聊聊Spring框架中的一个重要模块——Spring MVC。Spring MVC是一个基于MVC(Model-View-Controller)架构的Web框架,它提供了强大的功能来处理HTTP请求、生成动态内容以及管理Web应用程序的流程。无论是构建RESTfu…...

详解SQL数据查询功能

数据查询 一、 单表查询1. 选择表中的若干列2. 选择表中的若干元组3. ORDER BY 子句4. 聚合函数5. GROUP BY 子句6. LIMIT 子句综合示例: 二、 多表查询1. 等值连接查询 (Equi-Join)2. 非等值连接查询 (Non-Equi Join)3. 自然连接查询 (Natural Join)4. 复合条件连接…...

ArcGIS Pro 车牌分区数据处理与地图制作全攻略

在大数据时代,地理信息系统(GIS)技术在各个领域都有着广泛的应用,而 ArcGIS Pro 作为一款功能强大的 GIS 软件,为数据处理和地图制作提供了丰富的工具和便捷的操作流程。 车牌数据作为一种重要的地理空间数据&#xf…...

Git 本地常见快捷操作

Git 本地常见快捷操作 &#x1f4cc; 1. 基本操作 操作命令初始化 Git 仓库git init查看 Git 状态git status添加所有文件到暂存区git add .添加指定文件git add <file>提交更改git commit -m "提交信息"修改最后一次提交信息git commit --amend -m "新…...

大视频背景暗黑风格的wordpress企业主题免费下载

整体风格是黑色的&#xff0c;首页首屏大视频背景&#xff0c;动态效果非常好。向下滚动时&#xff0c;滚动的特效也不错。 原文 https://www.bixugao.com/wp/26.html...

Apache Tomcat漏洞,对其进行升级

我们付出一些成本&#xff0c;时间的或者其他&#xff0c;最终总能收获一些什么。 升级背景&#xff1a; 近日&#xff0c;新华三盾山实验室监测到 Apache 官方修复了一个远程代码执行漏洞 (CVE-2025-24813) &#xff0c;其CVSS3 漏洞评分为 7.5 。 影响范围 9.0.0.M1 ≤…...

fs的proxy_media模式失效

概述 freeswitch是一款简单好用的VOIP开源软交换平台。 在fs的使用过程中&#xff0c;某些场景只需要对rtp媒体做透传&#xff0c;又不需要任何处理。 在fs1.6的版本中&#xff0c;我们可以使用proxy_media来代理媒体的转发&#xff0c;媒体的协商由AB路端对端处理&#xff…...

Spring Boot与Apache Ignite集成:构建高性能分布式缓存和计算平台

1. 前言 1.1 什么是Apache Ignite Apache Ignite是一个高性能的分布式内存计算平台,支持内存缓存、分布式计算、流处理和机器学习等功能。它提供了低延迟的数据访问和强大的计算能力,适用于需要高性能和可扩展性的应用。 1.2 为什么选择Apache Ignite 高性能:Ignite利用内…...

深度学习优化-Gradient Checkpointing

数学原理参考&#xff1a; 梯度检查点技术&#xff08;Gradient Checkpointing&#xff09;详细介绍&#xff1a;中英双语-CSDN博客 视频讲解参考&#xff1a; 用梯度检查点来节省显存 gradient checkpointing_哔哩哔哩_bilibili Gradient Checkpointing&#xff08;梯度检查…...

Linux内核实时机制19 - RT调度器3 - 实时任务出入队

Linux内核实时机制19 - RT调度器3 - 实时任务出入队 1、enqueue_task_rt和dequeue_task_rt都会调用dequeue_rt_stack接口&#xff0c; 当请求的rt_se对应的是任务组时&#xff0c;会从顶部到请求的rt_se将调度实体出列。 2、任务添加到rt运行队列时&#xff0c; 如果存在多个…...

CRM企业客户关系管理系统产品原型方案

客户关系管理系统&#xff08;CRM&#xff09;是企业产品应用中的典范&#xff0c;旨在通过信息技术和互联网技术提升企业核心竞争力&#xff0c;优化企业与顾客在销售、营销和服务方面的互动。本作品提供了一套通用型的CRM系统原型模板&#xff0c;涵盖数据管理、审批流程、统…...

HashMap ,HashTable , ConcurrentHashMap 面试

双列集合 HashMap 线程不安全的 HashMap 允许键和值为 null。不过要留意&#xff0c;HashMap 并非线程安全的&#xff0c;在多线程环境下使用可能会出现问题。 数组链表红黑树 jdk1.8 双列集合 存储keyvalue 底层数组的形式存在,初始值 为16 也可以在new HashMap…...

PyTorch 系列教程:探索自然语言处理应用

本文旨在介绍如何使用PyTorch进行自然语言处理&#xff08;NLP&#xff09;的基础知识&#xff0c;包括必要的库、概念以及实际代码示例。通过阅读本文&#xff0c;您将能够开始您的NLP之旅。 1. 理解PyTorch PyTorch是一个开源的机器学习库&#xff0c;基于Torch库&#xff0…...

【操作系统安全】任务2:用户与用户组

目录 一、用户与用户组介绍 1.1 用户 1.2 用户组 1.3 用户与用户组的关系 二、用户与用户组管理 2.1 用户管理 2.1.1 创建用户 2.1.2 设置用户密码 2.1.3 删除用户 2.2 用户组管理 2.2.1 创建用户组 2.2.2 删除用户组 2.2.3 将用户添加到用户组 三、影子账户创建…...

DeepSeek技术解析:MoE架构实现与代码实战

以下是一篇结合DeepSeek技术解析与代码示例的技术文章&#xff0c;重点展示其核心算法实现与落地应用&#xff1a; DeepSeek技术解析&#xff1a;MoE架构实现与代码实战 作为中国AI领域的创新代表&#xff0c;DeepSeek在混合专家模型&#xff08;Mixture of Experts, MoE&…...

LLM对齐方法作用:主要解决大型语言模型(LLMs)输出与人类价值观、需求和安全规范不一致的问题

LLM对齐方法作用:主要解决大型语言模型(LLMs)输出与人类价值观、需求和安全规范不一致的问题 对齐方法(Alignment Methods) 主要解决大型语言模型(LLMs)输出与人类价值观、需求和安全规范不一致的问题。其核心目标是让模型生成的内容更符合人类预期,同时确保伦理合规性…...

【SpringMVC】常用注解:@RequestBody

1.作用 用于获取请求实体内容&#xff0c;直接使用得到的是keyvalue&keyvalue的数据。获取请求实体内容不适用get请求。 2.属性 required 描述是否有请求体&#xff0c;默认值为true。当取值为true时&#xff0c;get 请求方式会报错。如果取值为false&#xff0c;get请…...

brpc中的doublyBufferedData解析

double buffer解析&#xff08;附brpc改进版&#xff09; 双buffer是一个工程中常见的解决读写问题的结构。指的是读只读buff&#xff0c;写操作发生在写buff上。当写buff写完之后switch两个buff&#xff0c;然后写进程擦除原来的读数据&#xff0c;更新为最新的数据。 我们有…...

基于Android的记事本APP设计与实现:从需求分析到功能实现(超级简单记事本,附源码+文档报告)

基于Android的记事本APP设计与实现&#xff1a;从需求分析到功能实现 &#xff08;以前大学课堂作业&#xff0c;抄在这里当个回忆吧&#xff09; 引言 随着社会的不断进步&#xff0c;信息化建设不断发展&#xff0c;电子文字输入在生活、学习、工作中占有越来越重要的作用…...

Linux 部署 Spring Boot 项目, Web项目(2025版)

Linux 部署 Spring Boot 项目&#xff0c;Web项目&#xff08;2025版&#xff09; 一、简洁版1.1 Linux 环境配置1.2 将Spring Boot 项目部署到 Linux 中 二、详细版2.1 Linux 环境配置2.2 Spring Boot 项目搭建2.3 mysql 配置2.4 测试项目2.5 将Spring Boot 项目部署到 Linux …...

泛目录技术:智能缓存提升网站速度与稳定性

泛目录技术&#xff1a;智能缓存提升网站速度与稳定性 在现代网站运营中&#xff0c;速度和稳定性是用户体验和SEO优化的关键因素。2025奥顺互联推出的泛目录技术&#xff0c;通过智能缓存机制&#xff0c;为网站提供了卓越的性能提升和稳定性保障。本文将深入探讨该技术的特点…...

CNN SSP, ASPP, PPM 分割任务经典尺度聚合模块

SSP&#xff1a;Spatial Pyramid Pooling 让任意大小图像最终输出的特征维度始终固定&#xff0c;便于接全链接层。 4x4, 2x2,1x1区域的maxpooling&#xff0c;让任意大小图像最终输出最终特征维度始终为 &#xff08;1641)*256 ASSP:Atrous Spatial Pyramid Pooling 不进行…...

Nping- Nmap中的一个工具-用于生成网络数据包并分析响应

Nping 工具介绍 Nping 是 Nmap 项目中的一个网络工具&#xff0c;用于生成网络数据包并分析响应。它可以用于网络探测、性能测试、防火墙测试、ARP 欺骗检测等多种场景。Nping 支持多种协议&#xff08;如 TCP、UDP、ICMP、ARP&#xff09;&#xff0c;并允许用户自定义数据包…...

海马下载 1.0.2 | 纯净无广告,极简设计,不限速下载工具

海马下载是一款轻量级下载工具&#xff0c;仅保留核心链接下载功能&#xff0c;体积小巧仅21MB。实测无广告弹窗且不限速&#xff0c;适合追求简洁体验的用户。操作界面直观易用&#xff0c;可快速添加任务并查看下载进度。 大小&#xff1a;21M 下载地址&#xff1a; 百度网…...

【蓝桥杯—单片机】第十五届省赛真题代码题解析 | 思路整理

第十五届省赛真题代码题解析 前言赛题代码思路笔记竞赛板配置建立模板明确基本要求显示功能部分频率界面正常显示高位熄灭 参数界面基础写法&#xff1a;两个界面分开来写优化写法&#xff1a;两个界面合一起写 时间界面回显界面校准校准过程校准错误显示 DAC输出部分按键功能部…...

maven之自定义插件

写在前面 在使用maven肯定是离不开插件的&#xff0c;比如执行mvn clean或者时mvn compile其实运行的就是绑定的默认插件。虽然我们一般不需要来自定义插件&#xff0c;但是为了使用的过程中更加的清晰&#xff0c;来尝试自定义插件还是很有必要的&#xff0c;所以本文就一起来…...

Unity单例模式(c#泛型基类)

Unity单例模式 1 单例模式2 继承mono脚本单例模式基类3 SingletonAutoMono脚本 1 单例模式 单例模式基类模块 范型加约束,支持new来构造 //单例模式基类模块 //范型加约束,支持new来构造 public class BaseManager<T> where T :new() {private static T instance;public …...

java 中桥方法(Bridge Method)解决泛型和多态(即:类型兼容)而存在的

在 Java 中&#xff0c;**桥方法&#xff08;Bridge Method&#xff09;**是编译器自动生成的一种方法&#xff0c;主要用于解决泛型类型擦除和继承中的类型兼容性问题。以下是关于桥方法的几点关键信息&#xff1a; 1. 桥方法的作用 类型擦除兼容性&#xff1a;Java 的泛型在…...

Centos7阿里云yum源

#Step1:下载repository 没有wget命令 就用curl wget -O /etc/yum.repos.d/CentOS-Base.repo http://mirrors.aliyun.com/repo/Centos-7.repo curl -o /etc/yum.repos.d/CentOS-Base.repo http://mirrors.aliyun.com/repo/Centos-7.repo #Step2:安装epel基础组件源 没有wget命…...

leetcode 102. 二叉树的层序遍历

方法一&#xff1a; 用两个数组进行迭代遍历 class Solution {public List<List<Integer>> levelOrder(TreeNode root) {if(root null) {return new ArrayList<List<Integer>>();}List<TreeNode> cur new ArrayList<TreeNode>();cur.a…...

Trae插件革命:用VSPlugin Helper实现VSCode市场插件全自动安装

之前有读者留言说trae都没有c的插件用&#xff0c;确实是这样&#xff0c;trae的插件源用的是open vsx&#xff0c;而c/c插件是vscode官方插件市场的&#xff0c;如果想直接在trae中安装c/c插件是不行的&#xff0c;只能先从vscode官方插件市场把vsix后缀文件先下载下来&#x…...

SpringCloud带你走进微服务的世界

认识微服务 随着互联网行业的发展&#xff0c;对服务的要求也越来越高&#xff0c;服务架构也从单体架构逐渐演变为现在流行的微服务架构。这些架构之间有怎样的差别呢&#xff1f; 单体架构 单体架构&#xff1a;将业务的所有功能集中在一个项目中开发&#xff0c;打成一个包部…...

多线程(超详细) (ε≡٩(๑>₃<)۶ 一心向学)

多线程目录 一、认识线程 1、概念&#xff1a; 1) 线程是什么 2) 线程为什么存在 3) 进程与线程的区别 二、创建线程 1、方法1&#xff1a;继承Thread类 2、方法2&#xff1a;实现 Runnable 接口 3、方法3&#xff1a;匿名内部类创建 Thread 子类对象 4、方法4&#…...

LabVIEW旋转设备状态在线监测系统

为了提高大型旋转设备如电机和水泵的监控效率和故障诊断能力&#xff0c;用LabVIEW软件开发了一套实时监测与故障诊断系统。该系统集成了趋势分析、振动数据处理等多项功能&#xff0c;可实时分析电机电流、压力、温度及振动数据&#xff0c;以早期识别和预报故障。 ​ 项目背…...

RSS和TSS在网络流量处理中的优化作用

摘要 本文深入探讨了RSS(Receive Side Scaling)和TSS(Transmit Side Scaling)这两种网络流量处理技术的实现方法及其在网络性能优化中的重要作用。通过对硬件和软件实现方式的详细分析,阐述了它们如何在多队列网卡、多核处理器系统以及虚拟化环境中提升网络处理性能和吞吐…...

C++ 中的 RTTI(Run-Time Type Information,运行时类型识别)

我来为你详细讲解 C 中的 RTTI&#xff08;Run-Time Type Information&#xff0c;运行时类型识别&#xff09;&#xff0c;并结合你提供的参考内容进行分析和说明。 什么是 RTTI&#xff1f; RTTI 是 C 提供的一种机制&#xff0c;允许程序在运行时识别对象的类型信息。它主要…...

Netty基础—4.NIO的使用简介二

大纲 1.Buffer缓冲区 2.Channel通道 3.BIO编程 4.伪异步IO编程 5.改造程序以支持长连接 6.NIO三大核心组件 7.NIO服务端的创建流程 8.NIO客户端的创建流程 9.NIO优点总结 10.NIO问题总结 4.伪异步IO编程 (1)BIO的主要问题 (2)BIO编程模型的改进 (3)伪异步IO编程 …...

WPS 接入 DeepSeek-R1 深度实践:打造全能AI办公助手

一、智能化办公革命的技术底座 1.1 全球办公自动化发展现状 根据Gartner 2024年数字化转型报告显示&#xff0c;全球83%的企业已启动文档处理智能化改造&#xff0c;其中中国企业的AI办公渗透率以年均37%的增速领跑全球。WPS Office凭借其月活设备数突破5.6亿的生态优势&…...

MySQL与Redis的缓存一致性问题

MySQL与Redis的缓存一致性问题 前言 在学习中&#xff0c;为了提高数据的读取效率&#xff0c;我们往往会使用Redis来作为MySQL数据的缓存&#xff0c;那么&#xff0c;自然就产生了二者间数据的一致性问题。 想要对MySQL和Redis进行数据处理&#xff0c;自然会产生以下问题…...

【前端文件下载实现:多种表格导出方案的技术解析】

前端文件下载实现&#xff1a;多种表格导出方案的技术解析 背景介绍 在企业级应用中&#xff0c;数据导出是一个常见需求&#xff0c;特别是表格数据的导出。在我们的管理系统中&#xff0c;不仅需要支持用户数据的Excel导出&#xff0c;还需要处理多种格式的表格文件下载&am…...

933. 最近的请求次数

最近的请求次数 题目描述尝试做法推荐做法 题目描述 写一个 RecentCounter 类来计算特定时间范围内最近的请求。 请你实现 RecentCounter 类&#xff1a; RecentCounter() 初始化计数器&#xff0c;请求数为 0 。 int ping(int t) 在时间 t 添加一个新请求&#xff0c;其中 …...

[C++Qt] 槽函数收不到信号问题(信号的注册)

&#x1f4e2;博客主页&#xff1a;https://loewen.blog.csdn.net&#x1f4e2;欢迎点赞 &#x1f44d; 收藏 ⭐留言 &#x1f4dd; 如有错误敬请指正&#xff01;&#x1f4e2;本文由 丶布布原创&#xff0c;首发于 CSDN&#xff0c;转载注明出处&#x1f649;&#x1f4e2;现…...

吴恩达机器学习笔记复盘(三)Jupyter NoteBook

Jupyter NoteBook Jupyter是一个开源的交互式计算环境&#xff1a; 特点 交互式编程&#xff1a;支持以单元格为单位编写和运行代码&#xff0c;用户可以实时看到代码的执行结果&#xff0c;便于逐步调试和理解代码逻辑。多语言支持&#xff1a;不仅支持Python&#xff0c;还…...

面向对象Demo02

方法的调用的回顾 package oop; ​ public class Demo02 {//静态public static void main(String[] args) {//student student new student();student.speak();//非静态 //student student new student();} } package oop; ​ public class student {public static void sp…...

Quitzilla 学习版(安卓):戒掉坏习惯的高效助手

Quitzilla 是一款源自国外的日程管理工具&#xff0c;专为帮助用户戒除不良习惯而设计。它通过强大的习惯追踪功能和丰富的激励机制&#xff0c;让用户能够清晰地看到自己的进步&#xff0c;并逐步克服成瘾行为。这款软件的前身是一款戒烟应用&#xff0c;但经过改进后&#xf…...

AWB-illuminant_weight_vector

1.概念 光源权重向量 AWB 处理通过求取R/G-B/G 空间中灰色统计数据位置的平均值来估计光源, 此估计基于灰度世界假设. 因此, 输入统计数据中真实的灰色统计数据很重要. 通用环境下,灰色统计数据的平均值会遭到灰色区中的非灰色统计数据污染. 因此,估计结果的精确性依赖与选择灰…...

微信小程序面试内容整理-数据绑定

在微信小程序中,数据绑定是将 JavaScript 中的数据与 WXML 中的视图进行关联和同步的过程。它使得视图可以根据数据的变化自动更新,极大地简化了前端开发的复杂度。 数据绑定有两种主要类型: 1. 单向数据绑定:数据从 Java器更新到视图。...

蓝桥每日打卡--背包问题

#蓝桥#JAVA#背包问题 题目描述 有一个背包&#xff0c;它的容量为 W 4。有 3 个物品&#xff0c;它们的重量分别为 [2, 1, 3]&#xff0c;价值分别为 [4, 2, 3]。问在不超过背包容量的情况下&#xff0c;能装入背包的物品的最大价值是多少&#xff1f; 解题思路 动态规划的…...