【AI 加持下的 Python 编程实战 2_07】第七章:基于 Copilot 完整演示问题分解能力在实际问题中的落地应用
【全新第二版《Learn AI-assisted Python Programming》封面】
写在前面
问题分解能力在 AI 辅助编程中具有举足轻重的作用。但是怎样分解才算合理有效呢?本章从一个具体的案例切入,完整展示了GitHub Copilot
在自顶而下设计论的指导下圆满完成既定任务的方方面面,算是给大家打了个样。第二版的案例对比第一版感觉针对性更强,有意弱化了功能实现上的复杂度,便于读者从整体上把握问题分解的主要脉络,足见两位作者的用心程度。感兴趣的朋友可以用我在文末提供的附件链接在本地演练一遍,相信会有不小的收获。
Ch07: Problem decomposition
本章概要
- 理解问题分解的重要性
- 掌握自顶向下的设计方法并用以指导编程
- 实战:基于自顶向下设计的单词拼写建议程序
1 概述
与人类相同,Copilot
无法圆满完成一项描述模糊的任务。问题分解其实也是将任务具体化的重要组成部分。问题的合理分解对于后续高质量代码实现的重要性再怎么强调都不为过。对于大型项目而言,问题分解是合理控制复杂度的唯一途径。
本章通过 自顶向下 的设计思路来指导问题分解,并通过一个具体的单词拼接建议程序演示该方法的落地实践。
强大的问题分解能力需要日复一日的刻意练习。在与 AI 交互的过程中,多问几个类似 what...if...
句式的问题,可以较好地拓展问题本身,有利于从更通用、更宏观的角度重新审视当前的问题——这也是培养函数式思维方式(functional thinking
)的有效切入点。函数式编程思想的核心之一就是问题分解:一个大而模糊的问题通过各个功能点的有效拆分,最终可以细化到不同抽象层次的众多子问题上。当最底层的这些子问题都能通过某个函数来解决时,最初的大问题也迎刃而解。
小贴士
虽然函数式编程思想近年来得到了很大推广,但由于各种历史原因目前仍属于小众话题,在开发圈也出现了两极分化的趋势:要么将其妖魔化,认为它对数学功底要求甚高,后期调试扩展困难,唯恐避之而不及;要么将其万能化,认为万事万物皆可函数式编程,所有底层代码都可以用它重写一遍。
其实最合理的态度应该是折中路线:可以先了解函数式的思维方式,具体实践上再将其与其他开发范式(如面向对象编程、面向过程编程等)相结合,提高代码的整体质量。
2 问题描述
本章内容较为简单,直接引入后面的演示案例来拆解知识点。演示项目是一个基于 Python
简化版单词拼写建议程序,通过设计一个目标函数并传入一个可能存在拼写问题的英文单词、一组标准单词,最终得到该写法对应的参考单词。之所以称为简化版,是由于该程序只考虑三种情况的拼写问题:
- 传入单词比标准单词 多一个 英文字母:
catt
➡️cat
; - 传入单词比标准单词 少一个 英文字母:
mor
➡️more
; - 传入单词与标准单词之间 只存在一个不同的 英文字母:
sukcessful
➡️successful
;
3 问题分解演示
先梳理 输入、过程处理、输出 三个环节的任务描述:
阶段 | 任务描述 | 示例 |
---|---|---|
输入 | 即描述目标函数所需的各种参数。 | 共两个参数:一个待测单词,以及一组标准单词 |
过程处理 | 描述对传入参数的具体操作。 | 以 ried 为例,可以:1. 新增一个字母: fried ;2. 删除一个字母: red ;3. 替换一个字母: reed |
输出 | 返回最后的处理结果 | 以 ried 为例,返回:fried 、red 、reed |
3.1 初步拆分
最初的函数名根据 “单词拼写检查” 的含义推定为 spell_check
,从处理顺序上主要分三步:输入字符串、处理字符串、输出检查结果。
其中第一步和第三步很简单,分别使用 input
函数和 print
函数就能实现,不用拆分为独立的子问题,也就无需定义独立的函数。
第二步显然是需要定义函数的。根据上述表格的梳理,可以确定其主要功能是返回一组拼写建议,因此该函数可命名为 get_spelling_suggestions
。
接下来按照表格对 get_spelling_suggestions
再次拆分,具体如下:
3.2 输入环节
首先考察输入环节,即确定参数个数、参数名称、传参方式等。
作为 get_spelling_suggestions
参数之一的 待测单词 其实就是一个字符串,从上节讨论中的 input
函数手动输入即可,可命名为 possible_word
。
第二个参数需要认真考虑一下传参方式:这是一个单词列表;为了得到该列表,是直接硬编码到函数中好呢,还是通过一个文件名读取好呢?
从可维护性和可扩展性考虑,显然是后者。
既然是传一个包含所有参考单词的文件名,即文件名对应的完整路径字符串,那么问题又来了:该字符串究竟如何传入函数呢?也通过 input
函数传入吗?
这就涉及一个通用处理手法:参数配置——在调用最初的 spell_check
函数时,传入该字符串,将其 配置 到最外层函数,以供内部函数读取。根据含义,该参数可命名为 word_file
。
这样就确定了 get_spelling_suggestions
的两个参数:
possible_word
:表示待测字符串,从上一步input
函数手动输入;word_file
:表示参考单词所在的文件名,从调用spell_check
函数时以参数的形式完成手动配置;
3.3 过程处理环节
有了刚才分析得到的两个参数 possible_word
和 word_file
,过程处理环节又可以进一步拆分为三个子环节:
(1)生成标准单词组:根据 word_file
读取文件内容,得到参考单词组 word_list
。该函数可命名为 create_word_list
,参数为 file_name
,返回一个单词列表;
(2)生成所有潜在单词:根据此前确定的简化要求(增一、删一、改一),基于 possible_word
生成各种情况下的候选词列表。函数名可设计为 all_possible_words
,参数就是 possible_word
,返回一个潜在单词列表(possible_words
);
(3)过滤无效字符串:利用 word_list
将 possible_words
中的无效字符串清除,得到最终的拼写建议单词组。该函数可命名为 all_real_words
,接收参数为 word_list
和 possible_words
,返回筛选后的标准单词列表。
至此,就得到了第一版的问题分解示意图:
【图 7.1 经过初步分解后得到的函数结构示意图】
如图所示,右上角的 create_word_list
函数无需再次分解,利用 Python
的 open
命令即可完成;
第二个子函数 all_possible_words
其实又包含三个相互独立的情况,因此可以再次拆分成三个独立的函数,最后将处理结果汇总即可:
- 新增一个英文字母:函数名
add_letter
,考虑在每个字符的左右两侧新增a-z
的字母,然后返回处理结果; - 删除一个英文字母:函数名
delete_letter
,考虑删除不同位置的字母,将剩余部分汇总后作为处理结果返回; - 替换一个英文字母:函数名
change_letter
,与删除类似,将每个字符替换为除它本身以外的其他字母,再将替换结果汇总后返回;
显然,这三个子函数都接收一个参数 possible_word
,并且都返回一个候选词列表。于是示意图可以再次改写为:
【图 7.2 按新增、删除、修改三种情况再次拆分得到的函数结构示意图】
至此,所有的子函数均已拆分到原子级别,无需继续拆分。接下来考虑各函数的代码实现。
注意
实际操作过程中,每个问题应该拆分到什么程度算 原子级别 需根据具体情况确定,没有放之四海而皆准的统一标准。同样,这也是一个需要日积月累才能精进的本领。需要特别注意的是,本节给出的拆分思路也不是唯一的,例如我最开始设想的就是用标准单词去逐一匹配这三种情况,和作者思路恰恰相反。作者也强调,问题分解过程不可能每次都能一步到位,更多的情况是通过不断摸索试错,很可能是在拆分方案多次验证失败后才会得到一个较为满意的最终方案。
3.4 输出环节
从 get_spelling_suggestions
得到拼写建议 suggestions
后,使用 for
循环和 print
语句打印出所有建议即可:
for suggestion in suggestions:print(suggestion)
4 代码实现演示
根据自顶向下的设计思路,拆分问题是 从上到下 逐级展开的;具体的函数代码实现则是 自下而上 逐级归纳完成的。根据这个指导原则,具体实现顺序如下:
【图 7.3 各个主函数、子函数的代码实现顺序示意图】
接下来利用前面章节介绍的函数设计方法,基于 Copilot
分别实现如下(函数签名及 docstring
均为手动输入,其余为 Copilot
生成):
create_word_list()
:
def create_word_list(filename):'''filename is the name of a file that has one English word per line.Return a list of the words in the file.'''with open(filename, 'r') as f:words = [line.strip() for line in f]return words
add_letter()
:(先处理all_possible_words
的每个子函数)
def add_letter(word):'''word is a string with at least one letter.Return a list of all the strings that can be obtained byadding one letter to word.'''letters = 'abcdefghijklmnopqrstuvwxyz'result = []for i in range(len(word) + 1):for letter in letters:result.append(word[:i] + letter + word[i:])return result
delete_letter()
:
def delete_letter(word):'''word is a string with at least one letter.Return a list of all the strings that can be obtained bydeleting one letter from word.>>> delete_letter('carf')['arf', 'crf', 'caf', 'car']>>> delete_letter('a')['']'''result = []for i in range(len(word)):result.append(word[:i] + word[i + 1:])return result
这一步引入了测试用例,因此可以在下方添加测试语句:
import doctest
doctest.testmod(verbose = True)
change_letter()
:
def change_letter(word):'''word is a string with at least one letter.Return a list of all the strings that can be obtained bychanging one letter to another letter in word.'''letters = 'abcdefghijklmnopqrstuvwxyz'result = []for i in range(len(word)):for letter in letters:if letter != word[i]:result.append(word[:i] + letter + word[i + 1:])return result
all_possible_words()
:有了第 2、3、4 步的子函数,这一步只需将其结果汇总即可:
def all_possible_words(word):'''word is a string with at least one letter.Return a list of all the strings that can be obtained byadding one letter to word, deleting one letter from word,or changing one letter in word.'''result = []result += add_letter(word)result += delete_letter(word)result += change_letter(word)return result
all_real_words()
:
def all_real_words(word_list, possible_words):'''word_list is a list of English words.possible_words is a list of possible words.Return a list of words from possible_words that are in word_list.>>> english_words = ['scarf', 'cat', 'card', 'cafe']>>> possible_words = ['carfe', 'card', 'cat', 'cafe']>>> all_real_words(english_words, possible_words)['card', 'cat', 'cafe']'''result = []for word in possible_words:if word in word_list:result.append(word)return result
至此,get_spelling_suggestions()
函数的所有子函数均已实现完毕,上述过程可以实现一个做一个标记,如下图 7.4 所示:
【图 7.4 一边实现子函数一边做标记,可以有效避免错漏】
接着拼接第 1 步、第 5 步和第 6 步中的处理结果,得到第 7 步 get_spelling_suggestions()
函数的代码实现:
def get_spelling_suggestions(word_file, possible_word):'''word_file is the name of a file that has one English word per line.possible_word is a string that may or may not be a real word.Return the list of all possible unique corrections for possible_word.'''word_list = create_word_list(word_file)possible_words = all_possible_words(possible_word)real_words = all_real_words(word_list, possible_words)return list(set(real_words))
进而得到最终的 spell_check()
实现:
def spell_check(word_file):'''word_file is the name of a file that has one English word per line.Ask user for a word.Print all possible corrections for the word, one per line.'''word = input('Enter a word: ')suggestions = get_spelling_suggestions(word_file, word)if len(suggestions) == 0:print('No suggestions')else:print('Suggestions:')for suggestion in suggestions:print(suggestion)
5 功能测试
将本章附带的单词表文件 wordlist.txt
放入当前项目根目录,与示例代码 demo.py
平级,可以测得如下结果:
【图 7.5 实测单词拼写建议程序(符合预期)】
不同的待测内容得到的提示结果也截然不同:
> python demo.py
Enter a word: ried
Suggestions:
pried
riled
riend
ied
fried
rie
tried
pied
tied
dried
red
rid
died
reed
rien
lied
cried
rind
6 小结复盘
问题分解能力在 AI 辅助编程中至关重要,它同时也是控制大型问题复杂度的不二法门。GitHub Copilot
经过两年多的更新迭代,目前提供的参考代码段质量已经很高了。能否充分挖掘 AI 辅助编程的潜力,关键在于能否有效拆分并描述问题。建议大家在实测过程中不要复制粘贴文中的函数签名和注释内容,而是主动尝试手动输入(最好保持英文描述),效果会更好。
另外,本文提到的词汇表文件 wordlist.txt
可在这里免费获取:
链接:https://pan.baidu.com/s/1P5UClTKD1-xAscDH8Fravg?pwd=dwx5
提取码:dwx5
相关文章:
【AI 加持下的 Python 编程实战 2_07】第七章:基于 Copilot 完整演示问题分解能力在实际问题中的落地应用
【全新第二版《Learn AI-assisted Python Programming》封面】 写在前面 问题分解能力在 AI 辅助编程中具有举足轻重的作用。但是怎样分解才算合理有效呢?本章从一个具体的案例切入,完整展示了 GitHub Copilot 在自顶而下设计论的指导下圆满完成既定任务…...
React 路由入门秘籍:BrowserRouter 的江湖之道
前言 各位江湖中人,今日咱们聊一门流传在前端江湖的神秘绝学:<BrowserRouter>。此技出自 React 路由门派,专修客户端路由之道,擅长在 Web 世界中轻功跳转、闪转腾挪,悄无声息间掌控页面切换。 若你是构建现代 Web 应用的侠客,这篇秘籍堪比九阳真经,一经参悟,便…...
软件安装,systemctl命令,软连接
yum是centos里面的(apt是Ubuntu的) yum:RPM软件管理器,用于自动化安装配置Linux软件,并可以自动解决依赖问题 语法:yum 【-y】【install | remove | search | restart 】软件名称 -y:自动确…...
SpringBoot Actuator健康检查:自定义HealthIndicator
文章目录 引言一、Spring Boot Actuator健康检查概述二、自定义HealthIndicator的必要性三、实现自定义HealthIndicator四、高级健康检查配置五、实现自定义健康状态和响应码总结 引言 Spring Boot Actuator是Spring Boot框架中用于监控和管理应用程序的强大功能模块。它提供了…...
注意力机制(np计算示例)单头和多头
为了更好理解注意力机制里面的qkv矩阵,使用np来演示。 单头注意力 import numpy as np import math# 初始化输入 X X np.array([[[1, 2, 3], [4, 5, 6]]])# 初始化权重矩阵 WQ、WK、WV WQ np.array([[1, 0], [0, 1], [0, 0]])WK np.array([[1, 0], [0, 1], [0,…...
生成对抗网络(Generative adversarial network——GAN)
文章目录 1. 前言1.1 判别器和生成器的作用?2.2 个人总结 2. 核心代码示例2.1 训练判别器网络2.2 训练生成器网络 参考文章 1. 前言 生成对抗网络的原文:Generative Adversarial Nets,该论文的精读视频:生成对抗网络GAN开山之作论…...
CSGHub开源版本v1.6.0更新
CSGHub v1.6.0 带来了多项核心功能升级与性能优化,显著增强了对大模型推理、微调、评估等流程的支持,并进一步完善了推理服务与用户交互体验。 插件化推理与训练引擎框架 推理、微调和评估引擎现已全面模块化,支持通过配置文件灵活接入多种引…...
Redis日常学习(一)
我的Redis学习笔记:从命令行到性能调优 Redis Redis(Remote Dictionary Server)本质上是一个基于内存的键值存储系统. 安装配置Redis的过程非常简单: # Ubuntu/Debian安装Redis sudo apt-get update sudo apt-get install red…...
Unity3D仿星露谷物语开发37之浇水动画
1、目标 当点击水壶时,实现浇水的动画。同时有一个水从水壶中流出来的特效。 假如某个grid被浇过了,则不能再浇水了。。 如果某个grid没有被dug过,也不能被浇水。 2、优化Settings.cs脚本 增加如下内容: public static float…...
JavaScript 一维数组转不含零的两个数
问题描述: /*** param {number} n* return {number[]}*/ var getNoZeroIntegers function(n) {for(let i 1;i<n;i){if(String(i).indexOf(0) -1&&String(n-i).indexOf(0) -1){return [i,n-i]}}};String类型indexOf()函数如果找不到字串则返回-1&…...
抽象工厂模式及其在自动驾驶中的应用举例(c++代码实现)
模式定义 抽象工厂模式(Abstract Factory Pattern)是一种创建型设计模式,用于封装一组具有共同主题的独立对象创建过程。该模式通过提供统一接口创建相关对象家族,而无需指定具体实现类,特别适合需要保证系统组件兼容…...
知乎十四载:从精英问答到AI时代的知识灯塔
一、起源:Quora 的火种与周源的执念 2010 年,互联网浪潮正汹涌澎湃,各种新兴平台如雨后春笋般不断涌现。就在这一年的一个夜晚,周源像往常一样在网上浏览着各类信息,当他打开美国问答网站 Quora 时,瞬间被…...
Linux文件时间戳详解:Access、Modify、Change时间的区别与作用
在 Linux 系统中,文件的这三个时间戳(Access、Modify、Change)分别表示不同的文件状态变更时间,具体含义如下: 1. Access Time (Access) 含义:文件最后一次被访问的时间(读取内容或执行…...
Doris + Iceberg 构建冷热分层数据湖架构:架构设计与实战指南
在海量数据治理与存储演进中,冷热数据分层 已成为降本增效的关键策略。本篇将深入探讨如何结合 Apache Doris 与 Apache Iceberg 构建一套高性能、可扩展的数据湖架构,支持冷热数据自动分层、快速查询与灵活扩展。 一、背景:为什么需要冷热数…...
顺序表和链表的区别(C语言)
前言 线性表是最基础的数据结构之一,其中顺序表与链表分别代表两种存储方式: 顺序表(Sequential List):底层用数组实现,要求内存连续,典型代码以 int data[N] 或动态分配的 malloc/realloc 数…...
【Redis】Redis中的常见数据类型(一)
文章目录 前言一、Redis前置知识1. 全局命令2、数据结构和内部编码3. 单线程架构 二、String 字符串1. 常见命令2. 计数命令3.其他命令4. 内部编码5. 典型使用场景 三、Hash哈希1. 命令2.内部编码3. 使用场景4. 缓存方式对比 结语 前言 Redis 提供了 5 种数据结构,…...
Vue3 + TypeScript,使用祖先传后代模式重构父传子模式
父传子模式 父组件 SampleInput.vue <script setup lang"ts" name"SampleInput"> import { ref } from "vue"; import type { ApplyBasicInfo, Apply, ApplySample } from "/interface"; import CommonApplySampleTable from …...
MySQL:9.表的内连和外连
9.表的内连和外连 表的连接分为内连和外连 9.1 内连接 内连接实际上就是利用where子句对两种表形成的笛卡儿积进行筛选,之前查询都是内连 接,也是在开发过程中使用的最多的连接查询。 语法: select 字段 from 表1 inner join 表2 on 连接…...
(mac)Grafana监控系统之监控Linux的Redis
Grafana安装-CSDN博客 普罗米修斯Prometheus监控安装(mac)-CSDN博客 1.Redis_exporter安装 直接下载 wget https://github.com/oliver006/redis_exporter/releases/download/v1.0.3/redis_exporter-v1.0.3.linux-amd64.tar.gz 解压 tar -xvf redis_…...
Multisim使用教程详尽版--(2025最新版)
一、Multisim14前言 1.1、主流电路仿真软件 1. Multisim:NI开发的SPICE标准仿真工具,支持模拟/数字电路混合仿真,内置丰富的元件库和虚拟仪器(示波器、频谱仪等),适合教学和竞赛设计。官网:艾…...
python pdf转图片再OCR
先pdf转图片 import os from pdf2image import convert_from_path# PDF文件路径 pdf_path /Users/xxx/2022.pdf # 输出图片的文件夹 output_folder ./output_images2022 # 输出图片的命名格式 output_name page# 如果输出文件夹不存在,创建它 if not os.path.ex…...
npm link 使用指南
npm link 使用指南 npm link 是一个非常有用的命令,主要用于在开发过程中将本地 npm 包链接到全局 npm 目录,从而可以在其他项目中使用这个本地包,而不需要发布到 npm 仓库。 基本用法 1. 创建全局链接 进入你要链接的本地包的根目录&…...
免费图片软件,可矫正倾斜、调整去底效果
软件介绍 有个超棒的软件要给大家介绍一下哦,它就是——ImgTool,能实现图片漂白去底的功能,而且重点是,它是完全免费使用的呢,功能超强大! 软件特点及使用便捷性 这软件是绿色版本的哟,就像一…...
5G网络切片:精准分配资源,提升网络效率的关键技术
5G网络切片:精准分配资源,提升网络效率的关键技术 随着5G技术的广泛应用,网络切片(Network Slicing)作为其核心创新之一,正在改变传统网络架构。它通过将物理网络划分为多个逻辑网络(切片&…...
seate TCC模式案例
场景描述 用户下单时,需要创建订单并从用户账户中扣除相应的余额。如果订单创建成功但余额划扣失败,则需要回滚订单创建操作。使用 Seata 的 TCC 模式来保证分布式事务的一致性。 1. 项目结构 假设我们有两个微服务: Order Service&#x…...
Transfomer的本质
Transformer是一个基于自注意力机制的深度学习模型,用于处理序列数据,主要结构包括编码器和解码器,每个部分由多头自注意力和前馈网络组成,加上残差连接和层归一化,以及位置编码。它解决了RNN的并行处理问题࿰…...
final修饰变量的注意
在Java中,使用final修饰变量时,需注意以下关键事项: 1. 初始化规则 实例变量: 必须在声明时、构造器或实例初始化块中初始化。所有构造器分支必须保证初始化。 class Example {final int x; // 实例变量final int y;public Exampl…...
前端与传统接口的桥梁:JSONP解决方案
1.JSONP原理 1.1.动态脚本注入 说明:通过创建 <script> 标签绕过浏览器同源策略 1.2.回调约定 说明:服务端返回 函数名(JSON数据) 格式的JS代码 1.3.自动执行 说明:浏览器加载脚本后立即触发前端预定义的回调函数(现代开…...
SQL注入 01
0x01 用户、脚本、数据库之间的关系 首先客户端发出了ID36的请求,脚本引擎收到后将ID36的请求先代入脚本的sql查询语句Select * from A where id 36 , 然后将此代入到数据库中进行查询,查到后将返回查询到的所有记录给脚本引擎,接…...
Java之封装(学习笔记)
封装定义(个人理解:) 封装就像电视遥控器的按钮,比如音量键,对于我们使用者来说就是可以直接按下去调控音量,对于代码写作者来说就是封装了调控音量的方法,使得我们只能去调控,不能改…...
每天学一个 Linux 命令(27):head
可访问网站查看,视觉品味拉满: http://www.616vip.cn/27/index.html head 是 Linux 中用于查看文件开头部分内容的命令,默认显示文件前 10 行,适合快速预览文件结构或日志头部信息。 命令格式 head [选项] [文件]常用选项 选项说明-n <行数>指定显示前 N 行(如…...
山东大学软件学院创新项目实训开发日志(20)之中医知识问答自动生成对话标题bug修改
在原代码中存在一个bug:当前对话的标题不是现有对话的用户的第一段的前几个字,而是历史对话的第一段的前几个字。 这是生成标题的逻辑出了错误: 当改成size()-1即可...
论文阅读:2024 ICML Is DPO Superior to PPO for LLM Alignment? A Comprehensive Study
Is DPO Superior to PPO for LLM Alignment? A Comprehensive Study https://www.doubao.com/chat/3506902534329346 https://arxiv.org/pdf/2404.10719 速览 这篇论文主要探讨了大语言模型对齐中两种主流方法——**DPO(直接偏好优化)和PPO…...
2025年人工智能指数报告:技术突破与社会变革的全景透视
《2025年人工智能指数报告》作为斯坦福大学人工智能实验室与多方合作的年度重磅研究,以超过千页的篇幅全景式展现了人工智能技术在全球范围内的发展轨迹与深远影响。这份报告不仅延续了对AI技术性能、科研进展与产业应用的追踪,更首次深入探讨了AI硬件的…...
【Python笔记 01】变量、标识符
一、 变量 1、变量的作用 计算机存储空间,用于保存数据。 2、定义变量的格式 格式:变量名 值 示例: num1 3 # num1就是一个变量,保存蛋糕的价格 num2 10 #num2也是一个变量,保存雪碧的价格 total num1 num2 …...
WebSocket启用备忘
一:引入依赖: <!--WebSocket专用--><dependency><groupId>org.springframework.boot</groupId><artifactId>spring-boot-starter-websocket</artifactId></dependency><dependency><groupId>org…...
文件管理详解(曼波脑图版)
(✪ω✪)曼波来啦!文件管理的知识曼波这就为你详细讲解哟~ 记得要准备好小本本做笔记哦!(๑˃̵ᴗ˂̵)و 🌟 文件读写操作 🌟 // 最可爱的文件读取写法 (✧∇✧) try (BufferedReader reader new BufferedReader(new FileRead…...
学习笔记十九——Rust多态
🧩 Rust 多态终极通俗指南 📚 目录导航 多态一句话概念静态分派 vs 动态分派——根本差异参数化多态(泛型) 3.1 函数里的泛型 3.2 结构体里的泛型 3.3 方法里的泛型 3.4 枚举里的泛型Ad hoc 多态(特例多态࿰…...
在 Linux 上部署 .NET Core 应用并配置为开机自动启动
在本文中,我们将详细介绍如何在 Linux 系统上部署 .NET Core 应用程序,并配置为开机自动启动。以下是一步一步的详细部署过程,适用于将 .NET Core Web 应用部署到生产环境中。 1. 安装 .NET 运行时和 SDK 首先,确保 Linux 系统上…...
dubbo SPI插件扩展点使用
参考:SPI插件扩展点 Dubbo SPI概述 使用IoC容器帮助管理组件的生命周期、依赖关系注入等是很多开发框架的常用设计,Dubbo中内置了一个轻量版本的IoC容器,用来管理框架内部的插件,实现包括插件实例化、生命周期、依赖关系自动注入…...
P8512 [Ynoi Easy Round 2021] TEST_152 Solution
Description 有一序列 c ( c 1 , c 2 , ⋯ , c m ) c(c_1,c_2,\cdots,c_m) c(c1,c2,⋯,cm) 和 n n n 个三元组 ( l i , r i , v i ) (l_i,r_i,v_i) (li,ri,vi). 回答 q q q 次形如 ( L , R ) (L,R) (L,R) 的询问,具体如下: 将 c c …...
开源项目FastAPI-MCP:一键API转换MCP服务
在当今AI开发的世界中,应用程序与AI模型之间的无缝集成至关重要。 模型上下文协议(Model Context Protocol, MCP)通过允许AI模型访问外部工具和数据源,弥合了这一差距。 FastAPI MCP是一个强大的工具,它可以通过最少的配置将您现有的FastAPI端点转换为MCP兼容的工具。 本…...
8、constexpr if、inline、类模版参数推导、lambda的this捕获---c++17
一、constexpr if:编译时条件分支 作用:在模板编程中,根据条件在编译时选择不同的代码路径,无需特化版本或复杂SFINAE技巧[替代SFINAE]。[SFINAE将在模版元编程再讲。下个月了。]基本语法 if constexpr (condition) {// 如果 co…...
github新建一个远程仓库并添加了README.md,本地git仓库无法push
1.本地git仓库与远程仓库绑定 2.push时报错,本地的 main 分支落后于远程仓库的 main 分支(即远程有更新,但你本地没有),需要拉取远程的仓库--->在merge合并(解决冲突)--->push 3.但是git …...
贝叶斯分类器:原理、算法与应用详解
内容摘要 本文聚焦贝叶斯分类器,介绍其在各类分类器中分类错误概率最小的特性。详细阐述贝叶斯分类器的基本原理、朴素贝叶斯和半朴素贝叶斯分类器的算法,结合西瓜数据集实例说明朴素贝叶斯的应用。此外,还深入探讨极大似然估计和贝叶斯估计…...
算法篇之单调栈
单调栈算法入门 单调栈是一种特殊的数据结构应用,它的核心在于维护一个栈,使得栈内元素保持单调递增或者单调递减的顺序。这种数据结构在解决很多算法问题时非常有效,例如求数组中每个元素的下一个更大元素、每日温度问题等。 一、单调栈的…...
用python + PIL 实现图片格式转换工具
用python PIL 实现图片格式转换工具 要运行该程序,需要使用第三方库PIL(pillow),详情可见https://blog.csdn.net/cnds123/article/details/126141838 格式支持: 支持常见图片格式转换(JPEG, PNG, BMP, GIF…...
【数据库】事务
目录 1. 什么是事务? 2. 事务的ACID特性 3. 为什么使用事务? 4. 如何使用事务 4.1 查看支持事务的存储引擎 4.2 语法 4.3 保存点 4.4 自动/手动提交事务 5. 事物的隔离性和隔离级别 5.1 什么是隔离性 5.2 隔离级别 5.3 查看和设置隔离级别 1…...
C++:详解命名空间
目录 前言 一、命名空间是什么? 1.1命名空间域的定义 二、为什么有命名空间? 三、命名空间的用法 总结 前言 主要讲解命名空间是什么?为什么有命名空间?以及它的用法 一、命名空间是什么? 命名空间域(nam…...
ClickHouse核心架构设计
列式存储原理与数据压缩 列式存储原理 列式存储 vs 行式存储 特性行式存储(如MySQL)列式存储(ClickHouse)数据排列按行连续存储(所有字段相邻)按列连续存储(单列数据紧密排列)适用场…...