[{"data":1,"prerenderedAt":2878},["ShallowReactive",2],{"search-docs":3,"doc-\u002Fai\u002Ffundamentals\u002Fml-basics":886},[4,8,12,16,20,24,28,32,36,40,44,48,52,56,60,64,68,72,76,80,84,88,92,96,100,104,108,112,116,120,124,128,132,136,140,144,148,152,156,159,162,165,169,172,175,178,182,186,190,194,198,202,206,210,214,218,222,226,230,234,238,242,246,250,254,258,262,266,269,273,277,281,285,288,291,294,298,301,304,307,310,313,316,319,322,325,329,332,336,340,344,348,352,356,359,362,365,368,371,374,377,380,383,386,389,393,396,399,402,405,408,411,414,417,420,424,428,432,435,438,442,446,450,454,458,462,466,470,474,477,480,483,487,491,494,497,500,504,507,511,515,518,521,524,527,530,533,536,539,542,545,548,551,554,557,560,563,566,569,572,575,579,583,587,591,595,599,603,606,610,614,617,620,623,626,629,633,637,640,643,646,649,652,655,658,661,664,667,670,673,676,679,682,685,688,691,694,697,700,703,706,709,712,716,720,724,728,732,736,740,744,748,752,756,760,764,768,772,775,779,783,787,790,793,796,799,802,805,808,811,814,818,822,825,829,832,835,838,841,844,848,851,854,858,862,865,869,873,876,879,882],{"path":5,"title":6,"description":7},"\u002Fabout\u002Fauthor","作者相关","只想纯粹的做一个程序员...",{"path":9,"title":10,"description":11},"\u002Fabout\u002Fjourney","心路历程","",{"path":13,"title":14,"description":15},"\u002Fai\u002Fagent\u002Fframeworks","Agent 框架","主流 Agent 框架：LangChain、LlamaIndex、AutoGen、CrewAI",{"path":17,"title":18,"description":19},"\u002Fai\u002Fagent\u002Fhooks","Agent Hooks 与自动化","Claude Agent 的 Hooks 生命周期、事件类型、典型自动化场景",{"path":21,"title":22,"description":23},"\u002Fai\u002Fagent\u002Fintroduction","AI Agent 概述","AI Agent 核心概念：感知、规划、执行、记忆",{"path":25,"title":26,"description":27},"\u002Fai\u002Fagent\u002Fpractice","Agent 实战","AI Agent 实战：构建自主任务执行系统",{"path":29,"title":30,"description":31},"\u002Fai\u002Fagent\u002Fsdk","Claude Agent SDK 开发","使用 Claude Agent SDK 构建自定义 AI Agent：架构、API、生命周期",{"path":33,"title":34,"description":35},"\u002Fai\u002Fagent\u002Fsubagents","Subagents 子代理","用 Subagents 分解复杂任务、并发执行、隔离上下文",{"path":37,"title":38,"description":39},"\u002Fai\u002Fagent\u002Ftool-use","工具调用","AI Agent 工具调用：Function Calling、Tool Use 原理与实践",{"path":41,"title":42,"description":43},"\u002Fai\u002Ffundamentals\u002Fdeep-learning","深度学习入门","深度学习基础知识：前向传播、反向传播、损失函数、优化器",{"path":45,"title":46,"description":47},"\u002Fai\u002Ffundamentals\u002Fml-basics","机器学习基础","机器学习核心概念：监督学习、无监督学习、强化学习",{"path":49,"title":50,"description":51},"\u002Fai\u002Ffundamentals\u002Fneural-networks","神经网络原理","神经网络架构：CNN、RNN、注意力机制",{"path":53,"title":54,"description":55},"\u002Fai\u002Fgetting-started","AI 学习路线","AI 技术学习路线图，从基础到实战的完整指南",{"path":57,"title":58,"description":59},"\u002Fai\u002Fllm\u002Ffine-tuning","模型微调","大模型微调技术：LoRA、QLoRA、全量微调、RLHF",{"path":61,"title":62,"description":63},"\u002Fai\u002Fllm\u002Fintroduction","大模型概述","大语言模型发展历程、核心能力与主流模型对比",{"path":65,"title":66,"description":67},"\u002Fai\u002Fllm\u002Flocal-deploy","本地部署","大模型本地部署：Ollama、vLLM、llama.cpp",{"path":69,"title":70,"description":71},"\u002Fai\u002Fllm\u002Ftransformer","Transformer 架构","Transformer 架构详解：自注意力机制、位置编码、多头注意力",{"path":73,"title":74,"description":75},"\u002Fai\u002Fmcp\u002Fclient","MCP Client 开发","MCP Client 开发指南：连接、调用、集成",{"path":77,"title":78,"description":79},"\u002Fai\u002Fmcp\u002Fdebugging","MCP 调试与排错","MCP Server 开发与集成过程中的常见问题、日志分析、诊断工具",{"path":81,"title":82,"description":83},"\u002Fai\u002Fmcp\u002Fintroduction","MCP 概述","Model Context Protocol 协议概述：架构、核心概念、应用场景",{"path":85,"title":86,"description":87},"\u002Fai\u002Fmcp\u002Fserver","MCP Server 开发","MCP Server 开发指南：资源、工具、提示词的实现",{"path":89,"title":90,"description":91},"\u002Fai\u002Fmcp\u002Ftools","MCP Tools 深入","深入理解 MCP Tools：与 Resources\u002FPrompts 的差异、Schema 设计、Annotations 与权限控制",{"path":93,"title":94,"description":95},"\u002Fai\u002Fprompt\u002Fadvanced","高级 Prompt 模式","高级 Prompt 设计模式：Tree-of-Thought、自我反思、多轮对话策略",{"path":97,"title":98,"description":99},"\u002Fai\u002Fprompt\u002Fbasics","Prompt 基础","Prompt Engineering 入门：基本概念、角色设定、输出格式控制",{"path":101,"title":102,"description":103},"\u002Fai\u002Fprompt\u002Ftechniques","提示词技巧","常用提示词技巧：Few-shot、Chain-of-Thought、ReAct",{"path":105,"title":106,"description":107},"\u002Fai\u002Frag\u002Fembedding","文本嵌入","文本嵌入模型：Embedding 原理、模型选择、相似度计算",{"path":109,"title":110,"description":111},"\u002Fai\u002Frag\u002Fintroduction","RAG 概述","检索增强生成（RAG）架构原理、优势与应用场景",{"path":113,"title":114,"description":115},"\u002Fai\u002Frag\u002Fpractice","RAG 实战","RAG 应用实战：文档问答系统、知识库搭建",{"path":117,"title":118,"description":119},"\u002Fai\u002Frag\u002Fvector-database","向量数据库","主流向量数据库对比：Milvus、Pinecone、Chroma、Weaviate",{"path":121,"title":122,"description":123},"\u002Fai\u002Fskills\u002Fbest-practices","Skill 最佳实践","编写高质量 Skill 的设计原则、常见陷阱与优化技巧",{"path":125,"title":126,"description":127},"\u002Fai\u002Fskills\u002Fcreating","创建自定义 Skill","从零编写一个可被 Agent 自动发现和调用的 Skill",{"path":129,"title":130,"description":131},"\u002Fai\u002Fskills\u002Fintroduction","Agent Skills 概述","Claude Agent Skills 概念、工作原理、与 Tools\u002FMCP 的区别",{"path":133,"title":134,"description":135},"\u002Fgolang\u002Fadvanced\u002Fconcurrency","Go - 并发深入","深入理解 Go 并发编程的核心机制。",{"path":137,"title":138,"description":139},"\u002Fgolang\u002Fadvanced\u002Fgc","Go - 垃圾回收","理解 Go 的垃圾回收机制，掌握 GC 调优方法。",{"path":141,"title":142,"description":143},"\u002Fgolang\u002Fadvanced\u002Fgmp","Go - GMP 调度模型","GMP 是 Go 运行时调度器的核心模型，理解它对于编写高性能 Go 程序至关重要。",{"path":145,"title":146,"description":147},"\u002Fgolang\u002Fadvanced\u002Fgo-concurrency","Go - 并发编程","Go 的并发是其核心特性之一，通过 Goroutine 和 Channel 实现。",{"path":149,"title":150,"description":151},"\u002Fgolang\u002Fadvanced\u002Fmemory","Go - 内存模型","理解 Go 的内存分配机制和内存模型。",{"path":153,"title":154,"description":155},"\u002Fgolang\u002Fadvanced\u002Fprofiling","Go - 性能分析","掌握 Go 的性能分析工具：pprof、trace、benchmark。",{"path":157,"title":158,"description":11},"\u002Fgolang\u002Fcore\u002Fgo-basic","Go - 基础语法",{"path":160,"title":161,"description":11},"\u002Fgolang\u002Fcore\u002Fgo-composite","Go - 复合类型",{"path":163,"title":164,"description":11},"\u002Fgolang\u002Fcore\u002Fgo-control","Go - 流程控制",{"path":166,"title":167,"description":168},"\u002Fgolang\u002Fcore\u002Fgo-error","Go - 错误处理","Go 使用显式的错误返回值来处理错误，而不是异常机制。",{"path":170,"title":171,"description":11},"\u002Fgolang\u002Fcore\u002Fgo-function","Go - 函数",{"path":173,"title":174,"description":11},"\u002Fgolang\u002Fcore\u002Fgo-install","Go - 环境搭建",{"path":176,"title":177,"description":11},"\u002Fgolang\u002Fcore\u002Fgo-interface","Go - 接口",{"path":179,"title":180,"description":181},"\u002Fgolang\u002Fcore\u002Fgo-module","Go - 包管理","Go Modules 是 Go 1.11 引入的官方依赖管理方案，Go 1.16 后成为默认模式。",{"path":183,"title":184,"description":185},"\u002Fgolang\u002Fdistributed\u002Fgrpc","Go - gRPC","gRPC 是 Google 开发的高性能 RPC 框架，使用 Protocol Buffers 作为序列化协议。",{"path":187,"title":188,"description":189},"\u002Fgolang\u002Fdistributed\u002Fmicroservice","Go - 微服务","微服务架构的核心组件：服务发现、负载均衡、熔断降级。",{"path":191,"title":192,"description":193},"\u002Fgolang\u002Fdistributed\u002Fmq","Go - 消息队列","使用 Go 操作 Kafka 和 RabbitMQ。",{"path":195,"title":196,"description":197},"\u002Fgolang\u002Fdistributed\u002Fredis","Go - Redis","使用 go-redis 操作 Redis，实现缓存、分布式锁等功能。",{"path":199,"title":200,"description":201},"\u002Fgolang\u002Fengineering\u002Fconfig","Go - 配置管理","使用 viper 进行配置管理，支持多种配置格式和配置中心。",{"path":203,"title":204,"description":205},"\u002Fgolang\u002Fengineering\u002Fdocker","Go - Docker 部署","使用 Docker 容器化部署 Go 应用。",{"path":207,"title":208,"description":209},"\u002Fgolang\u002Fengineering\u002Fkubernetes","Go - Kubernetes 部署","在 Kubernetes 上部署和管理 Go 应用。",{"path":211,"title":212,"description":213},"\u002Fgolang\u002Fengineering\u002Flogging","Go - 日志系统","使用 zap 和 logrus 构建高性能结构化日志系统。",{"path":215,"title":216,"description":217},"\u002Fgolang\u002Fengineering\u002Ftesting","Go - 单元测试","Go 内置了强大的测试框架，掌握测试是编写高质量代码的基础。",{"path":219,"title":220,"description":221},"\u002Fgolang\u002Fstdlib\u002Fbufio","bufio","在 Go 语言中，bufio 包提供了带缓冲的 I\u002FO 操作，能够提高读写性能。以下是一些常用的 bufio 包 API 及其详细说明：",{"path":223,"title":224,"description":225},"\u002Fgolang\u002Fstdlib\u002Fcontainer","container","在Go语言标准库中，container 包提供了几种常用的数据结构实现，这些数据结构对于高效地管理和操作数据非常有用。以下是 container 包中主要的数据结构：",{"path":227,"title":228,"description":229},"\u002Fgolang\u002Fstdlib\u002Fcrypto","crypto","在 Go 语言中，crypto 包提供了一组用于加密和解密的功能。以下是一些常用的 crypto 包及其子包的 API 及其详细说明：",{"path":231,"title":232,"description":233},"\u002Fgolang\u002Fstdlib\u002Fencoding-csv","encoding\u002Fcsv","在 Go 语言中，encoding\u002Fcsv 包提供了对 CSV（逗号分隔值）文件进行读写的功能。以下是一些常用的 encoding\u002Fcsv 包的 API 及其详细说明：",{"path":235,"title":236,"description":237},"\u002Fgolang\u002Fstdlib\u002Fencoding-json","encoding\u002Fjson","在 Go 语言中，encoding\u002Fjson 包提供了对 JSON 数据进行编码和解码的功能。以下是一些常用的 encoding\u002Fjson 包的 API 及其详细说明：",{"path":239,"title":240,"description":241},"\u002Fgolang\u002Fstdlib\u002Fencoding-xml","encoding\u002Fxml","在 Go 语言中，encoding\u002Fxml 包提供了对 XML 数据进行编码和解码的功能。以下是一些常用的 encoding\u002Fxml 包的 API 及其详细说明：",{"path":243,"title":244,"description":245},"\u002Fgolang\u002Fstdlib\u002Fflag","flag","在Go语言中，flag 包是用于处理命令行参数的标准库，它提供了一种简单而直接的方式来解析和使用命令行参数。下面是关于 flag 包的一些基本介绍和常用功能：",{"path":247,"title":248,"description":249},"\u002Fgolang\u002Fstdlib\u002Ffmt","fmt","在 Go 语言的标准库中，fmt 包是非常重要的，它提供了处理格式化输入和输出的基本工具。以下是一些 fmt 包内常用的API：",{"path":251,"title":252,"description":253},"\u002Fgolang\u002Fstdlib\u002Fhttp","net\u002Fhttp","在 Go 语言中，net\u002Fhttp 包提供了用于构建 HTTP 客户端和服务器的强大工具。以下是一些常用的 net\u002Fhttp 包的 API 及其详细说明：",{"path":255,"title":256,"description":257},"\u002Fgolang\u002Fstdlib\u002Fio","io","在 Go 语言中，io 包提供了基本的输入输出功能。以下是一些常用的 io 包的 API 及其详细说明：",{"path":259,"title":260,"description":261},"\u002Fgolang\u002Fstdlib\u002Flog","log","在 Go 语言中，log 包提供了简单的日志记录功能。以下是一些常用的 log 包的 API 及其详细说明：",{"path":263,"title":264,"description":265},"\u002Fgolang\u002Fstdlib\u002Fmath","math","在 Go 语言中，math 包提供了基本的数学函数和常量。以下是一些常用的 math 包的 API 及其详细说明：",{"path":267,"title":268,"description":11},"\u002Fgolang\u002Fstdlib\u002Fnet","net",{"path":270,"title":271,"description":272},"\u002Fgolang\u002Fstdlib\u002Fos","os","在Go语言中，os 包是一个非常重要且常用的标准库，它提供了与操作系统交互的功能，包括文件操作、环境变量管理、进程管理等。下面是一些 os 包中常用的功能和API：",{"path":274,"title":275,"description":276},"\u002Fgolang\u002Fstdlib\u002Fsort","order","在 Go 语言中，sort 包提供了对切片和用户定义的集合进行排序的函数。它实现了常见的排序算法，如快速排序（Quicksort）和堆排序（Heapsort），并且为自定义集合提供了接口，使得用户可以根据特定的需求进行排序。",{"path":278,"title":279,"description":280},"\u002Fgolang\u002Fstdlib\u002Fstrconv","strconv","在 Go 语言中，strconv 包提供了字符串和基本数据类型之间的转换函数，例如将整数转换为字符串、字符串转换为整数，以及其他类型之间的转换。这些功能非常有用，特别是在处理用户输入或从外部数据源读取数据时。",{"path":282,"title":283,"description":284},"\u002Fgolang\u002Fstdlib\u002Ftime","time","在 Go 语言中，time 包提供了处理时间和日期的功能。以下是一些常用的 time 包的 API 及其详细说明：",{"path":286,"title":287,"description":11},"\u002Fgolang\u002Fweb\u002Fgin\u002Ferror","Gin - 错误处理",{"path":289,"title":290,"description":11},"\u002Fgolang\u002Fweb\u002Fgin\u002Ffile","Gin - 文件处理",{"path":292,"title":293,"description":11},"\u002Fgolang\u002Fweb\u002Fgin\u002Fmiddleware","Gin - 中间件",{"path":295,"title":296,"description":297},"\u002Fgolang\u002Fweb\u002Fgin\u002Fquickstart","Gin - 快速开始","Gin 是目前最流行的 Go Web 框架，以高性能和简洁 API 著称。",{"path":299,"title":300,"description":11},"\u002Fgolang\u002Fweb\u002Fgin\u002Frequest","Gin - 请求处理",{"path":302,"title":303,"description":11},"\u002Fgolang\u002Fweb\u002Fgin\u002Fresponse","Gin - 响应处理",{"path":305,"title":306,"description":11},"\u002Fgolang\u002Fweb\u002Fgin\u002Frouter","Gin - 路由",{"path":308,"title":309,"description":11},"\u002Fgolang\u002Fweb\u002Fgin\u002Fvalidation","Gin - 参数校验",{"path":311,"title":312,"description":11},"\u002Fgolang\u002Fweb\u002Fgorm\u002Fassociation","GORM - 关联关系",{"path":314,"title":315,"description":11},"\u002Fgolang\u002Fweb\u002Fgorm\u002Fcrud","GORM - CRUD 操作",{"path":317,"title":318,"description":11},"\u002Fgolang\u002Fweb\u002Fgorm\u002Fmodel","GORM - 模型定义",{"path":320,"title":321,"description":11},"\u002Fgolang\u002Fweb\u002Fgorm\u002Fperformance","GORM - 日志与性能",{"path":323,"title":324,"description":11},"\u002Fgolang\u002Fweb\u002Fgorm\u002Fquery","GORM - 高级查询",{"path":326,"title":327,"description":328},"\u002Fgolang\u002Fweb\u002Fgorm\u002Fquickstart","GORM - 快速开始","GORM 是 Go 语言最流行的 ORM 库，功能强大，使用简单。",{"path":330,"title":331,"description":11},"\u002Fgolang\u002Fweb\u002Fgorm\u002Ftransaction","GORM - 事务与 Hook",{"path":333,"title":334,"description":335},"\u002Finterview\u002Fbasic","计算机基础面经","本章节汇总了面试中常见的通用技术概念，不局限于特定语言或数据库，是考察技术内功的关键考点。",{"path":337,"title":338,"description":339},"\u002Finterview\u002Fgolang","Golang 面试题","Go 语言面试高频考点，覆盖基础语法、数据结构、并发编程、内存管理、GC、调度器等核心知识。",{"path":341,"title":342,"description":343},"\u002Finterview\u002Fk8s","Kubernetes 面试题","Kubernetes（K8s）面试高频考点，覆盖架构原理、核心资源、网络存储、调度策略、运维监控等核心知识。",{"path":345,"title":346,"description":347},"\u002Finterview\u002Fmysql","MySQL 面试题","MySQL 数据库面试高频考点，覆盖索引、事务、锁、优化、主从复制等核心知识。",{"path":349,"title":350,"description":351},"\u002Finterview\u002Fredis","Redis 面试题","Redis 面试高频考点，覆盖数据结构、持久化、集群、缓存一致性、性能优化等核心知识。",{"path":353,"title":354,"description":355},"\u002Finterview\u002Frocketmq","RocketMQ 面试题","RocketMQ 面试高频考点，覆盖消息模型、可靠性、顺序消息、事务消息、存储与高可用等核心知识。",{"path":357,"title":358,"description":11},"\u002Fother\u002Fjava\u002Fcollection\u002Flist-arraylist","List - ArrayList 源码解析",{"path":360,"title":361,"description":11},"\u002Fother\u002Fjava\u002Fcollection\u002Flist-linkedlist","List - LinkedList 源码解析",{"path":363,"title":364,"description":11},"\u002Fother\u002Fjava\u002Fcollection\u002Flist-stack","List - Satck源码解析",{"path":366,"title":367,"description":11},"\u002Fother\u002Fjava\u002Fcollection\u002Flist-vectore","List - Vector 源码解析",{"path":369,"title":370,"description":11},"\u002Fother\u002Fjava\u002Fcollection\u002Fmap-hashmap","Map - HashMap 源码解析",{"path":372,"title":373,"description":11},"\u002Fother\u002Fjava\u002Fcollection\u002Fmap-linkedhashmap","Map - LinkedHashMap 源码解析",{"path":375,"title":376,"description":11},"\u002Fother\u002Fjava\u002Fcollection\u002Fmap-treemap","Map - TreeMap 源码解析",{"path":378,"title":379,"description":11},"\u002Fother\u002Fjava\u002Fcollection\u002Fqueue-deque","Queue - Deque 接口解析",{"path":381,"title":382,"description":11},"\u002Fother\u002Fjava\u002Fcollection\u002Fqueue-queue","Queue - Queue 接口解析",{"path":384,"title":385,"description":11},"\u002Fother\u002Fjava\u002Fcollection\u002Fset-hashset","Set - HashSet源码解析",{"path":387,"title":388,"description":11},"\u002Fother\u002Fjava\u002Fcollection\u002Fset-linkedhashset","Set - LinkedHashSet 源码解析",{"path":390,"title":391,"description":392},"\u002Fother\u002Fjava\u002Fcollection\u002Fset-treeset","Set - TreeSet源码解析","TreeSet 是一个 Set 集合接口的实现类，与 HashSet 类似，其底层也是通过维护了一个 TreeMap 对象来封装了一些实现方法，故本篇不再对 TreeSet 的底层原理进行详细说明，仅对常用 API 做简单介绍，如需了解 TreeMap 的底层实现原理，请移步 Map - HashMap 源码解析",{"path":394,"title":395,"description":11},"\u002Fother\u002Fjava\u002Fcore\u002Fannotation","Java核心 - 注解",{"path":397,"title":398,"description":11},"\u002Fother\u002Fjava\u002Fcore\u002Fbasic-grammar","Java核心 - 基础语法",{"path":400,"title":401,"description":11},"\u002Fother\u002Fjava\u002Fcore\u002Fclass-and-object","Java核心 - 面向对象",{"path":403,"title":404,"description":11},"\u002Fother\u002Fjava\u002Fcore\u002Fcommon-classes","Java核心 - 常用类",{"path":406,"title":407,"description":11},"\u002Fother\u002Fjava\u002Fcore\u002Fexception","Java核心 - 异常处理",{"path":409,"title":410,"description":11},"\u002Fother\u002Fjava\u002Fcore\u002Fgenerics","Java核心 - 泛型",{"path":412,"title":413,"description":11},"\u002Fother\u002Fjava\u002Fcore\u002Fjdk-env-path","Java核心 - 环境搭建",{"path":415,"title":416,"description":11},"\u002Fother\u002Fjava\u002Fcore\u002Freflection","Java核心 - 反射",{"path":418,"title":419,"description":11},"\u002Fother\u002Fjava\u002Fcore\u002Fstring","Java核心 - String 字符串",{"path":421,"title":422,"description":423},"\u002Fother\u002Fjava\u002Fio\u002Fbuffer-stream","Java IO - 缓冲流","缓冲流是对基本流的包装，通过内置缓冲区减少系统调用次数，大幅提升读写效率。",{"path":425,"title":426,"description":427},"\u002Fother\u002Fjava\u002Fio\u002Fbyte-stream","Java IO - 字节流","字节流是 Java IO 中最基本的流类型，以字节（byte）为单位进行数据读写，可以处理任意类型的文件。",{"path":429,"title":430,"description":431},"\u002Fother\u002Fjava\u002Fio\u002Fchar-stream","Java IO - 字符流","字符流以字符为单位进行读写，专门用于处理文本文件。相比字节流，字符流能够正确处理字符编码，避免中文乱码问题。",{"path":433,"title":434,"description":11},"\u002Fother\u002Fjava\u002Fio\u002Ffile","Java IO - File 类",{"path":436,"title":437,"description":11},"\u002Fother\u002Fjava\u002Fio\u002Fio-stream-system","Java IO - IO流概述",{"path":439,"title":440,"description":441},"\u002Fother\u002Fjava\u002Fio\u002Fnio","Java IO - NIO","NIO（New IO）是 JDK 1.4 引入的新 IO 模型，提供了更高效的 IO 操作方式，支持非阻塞 IO 和多路复用。",{"path":443,"title":444,"description":445},"\u002Fother\u002Fjava\u002Fjvm\u002Fclass-loading","类加载机制","类加载机制是 JVM 将 .class 文件加载到内存，并对数据进行校验、转换解析和初始化，最终形成可被 JVM 直接使用的 Java 类型的过程。",{"path":447,"title":448,"description":449},"\u002Fother\u002Fjava\u002Fjvm\u002Fgarbage-collection","垃圾回收","垃圾回收（Garbage Collection，GC）是 JVM 自动管理内存的机制，负责回收不再使用的对象所占用的内存。",{"path":451,"title":452,"description":453},"\u002Fother\u002Fjava\u002Fjvm\u002Fjvm-memory","JVM 内存结构","JVM 在执行 Java 程序时，会把它管理的内存划分为若干个不同的数据区域。这些区域有各自的用途、创建和销毁时间。",{"path":455,"title":456,"description":457},"\u002Fother\u002Fjava\u002Fjvm\u002Fjvm-tuning","JVM 调优","JVM 调优是优化 Java 应用性能的重要手段，主要包括参数配置、性能监控和问题排查。",{"path":459,"title":460,"description":461},"\u002Fother\u002Fjava\u002Fthread\u002Fatomic","原子类","Java 原子类（Atomic Classes）提供了一种无锁的线程安全方式，基于 CAS（Compare-And-Swap）操作实现。",{"path":463,"title":464,"description":465},"\u002Fother\u002Fjava\u002Fthread\u002Fcompletable-future","CompletableFuture","CompletableFuture 是 JDK 8 引入的异步编程工具，实现了 Future 和 CompletionStage 接口，支持函数式编程和链式调用。",{"path":467,"title":468,"description":469},"\u002Fother\u002Fjava\u002Fthread\u002Fconcurrent-collections","并发集合","Java 并发包提供了多种线程安全的集合类，用于替代传统的同步集合（如 Collections.synchronizedList）。",{"path":471,"title":472,"description":473},"\u002Fother\u002Fjava\u002Fthread\u002Fconcurrent-utils","并发工具类","Java 并发包提供了多种实用的并发工具类，用于控制线程之间的协调与同步。",{"path":475,"title":476,"description":11},"\u002Fother\u002Fjava\u002Fthread\u002Fsynchronized-lock","同步机制",{"path":478,"title":479,"description":11},"\u002Fother\u002Fjava\u002Fthread\u002Fthread-basic","线程基础",{"path":481,"title":482,"description":11},"\u002Fother\u002Fjava\u002Fthread\u002Fthread-pool","线程池",{"path":484,"title":485,"description":486},"\u002Fother\u002Fspring-series\u002Fspring\u002Fannotations-beans","Spring - 基于注解管理Bean","从 Java 5 开始，Java 增加了对注解（Annotation）的支持，它是代码中的一种特殊标记，可以在编译、类加载和运行时被读取，执行相应的处理。开发人员可以通过注解在不改变原有代码和逻辑的情况下，在源代码中嵌入补充信息。",{"path":488,"title":489,"description":490},"\u002Fother\u002Fspring-series\u002Fspring\u002Fimplement-ioc","Spring - 原理手写IoC","Spring 框架的 IOC 是基于 Java 反射机制实现的，在学习手写 IoC 之前，你需要具备一定的 Java 反射相关的知识，参考本站内的 Java 教程。",{"path":492,"title":493,"description":11},"\u002Fother\u002Fspring-series\u002Fspring\u002Fintroduction-case","Spring - 入门案例",{"path":495,"title":496,"description":11},"\u002Fother\u002Fspring-series\u002Fspring\u002Fspring-aop","Spring - 面向切面AOP",{"path":498,"title":499,"description":11},"\u002Fother\u002Fspring-series\u002Fspring\u002Fspring-aot","Spring - AOT提前编译",{"path":501,"title":502,"description":503},"\u002Fother\u002Fspring-series\u002Fspring\u002Fspring-data-validation","Spring - 数据校验","在开发中，我们经常遇到参数校验的需求，比如用户注册的时候，要校验用户名不能为空、用户名长度不超过20个字符、手机号是合法的手机号格式等等。如果使用普通方式，我们会把校验的代码和真正的业务处理逻辑耦合在一起，而且如果未来要新增一种校验逻辑也需要在修改多个地方。而spring validation允许通过注解的方式来定义对象校验规则，把校验和业务逻辑分离开，让代码编写更加方便。Spring Validation其实就是对Hibernate Validator进一步的封装，方便在Spring中使用。",{"path":505,"title":506,"description":11},"\u002Fother\u002Fspring-series\u002Fspring\u002Fspring-i18n","Spring - 国际化i18n",{"path":508,"title":509,"description":510},"\u002Fother\u002Fspring-series\u002Fspring\u002Fspring-ioc","Spring - IOC容器","IoC 是 Inversion of Control 的简写，译为“控制反转”，它不是一门技术，而是一种设计思想，是一个重要的面向对象编程法则，能够指导我们如何设计出松耦合、更优良的程序。",{"path":512,"title":513,"description":514},"\u002Fother\u002Fspring-series\u002Fspring\u002Fspring-junit","Spring - 单元测试JUnit","在之前的测试方法中，几乎都能看到以下的两行代码：",{"path":516,"title":517,"description":11},"\u002Fother\u002Fspring-series\u002Fspring\u002Fspring-resources","Spring - 资源操作",{"path":519,"title":520,"description":11},"\u002Fother\u002Fspring-series\u002Fspring\u002Fspring-summarize","Spring - Spring概述",{"path":522,"title":523,"description":11},"\u002Fother\u002Fspring-series\u002Fspring\u002Fspring-transaction","Spring - 事务",{"path":525,"title":526,"description":11},"\u002Fother\u002Fspring-series\u002Fspring\u002Fxml-beans","Spring - 基于XML管理Bean",{"path":528,"title":529,"description":11},"\u002Fother\u002Fspring-series\u002Fspringboot\u002Fspringboot-config","SpringBoot - 配置详解",{"path":531,"title":532,"description":11},"\u002Fother\u002Fspring-series\u002Fspringboot\u002Fspringboot-data","SpringBoot - 数据访问",{"path":534,"title":535,"description":11},"\u002Fother\u002Fspring-series\u002Fspringboot\u002Fspringboot-quickstart","SpringBoot - 快速入门",{"path":537,"title":538,"description":11},"\u002Fother\u002Fspring-series\u002Fspringboot\u002Fspringboot-web","SpringBoot - Web 开发",{"path":540,"title":541,"description":11},"\u002Fother\u002Fspring-series\u002Fspringcloud\u002Fspringcloud-config","SpringCloud - 配置中心",{"path":543,"title":544,"description":11},"\u002Fother\u002Fspring-series\u002Fspringcloud\u002Fspringcloud-discovery","SpringCloud - 服务注册与发现",{"path":546,"title":547,"description":11},"\u002Fother\u002Fspring-series\u002Fspringcloud\u002Fspringcloud-feign","SpringCloud - 服务调用",{"path":549,"title":550,"description":11},"\u002Fother\u002Fspring-series\u002Fspringcloud\u002Fspringcloud-gateway","SpringCloud - 服务网关",{"path":552,"title":553,"description":11},"\u002Fother\u002Fspring-series\u002Fspringcloud\u002Fspringcloud-introduction","SpringCloud - 微服务概述",{"path":555,"title":556,"description":11},"\u002Fother\u002Fspring-series\u002Fspringcloud\u002Fspringcloud-sentinel","SpringCloud - 服务保护",{"path":558,"title":559,"description":11},"\u002Fother\u002Fspring-series\u002Fspringmvc\u002Fspringmvc-databind","SpringMVC - 数据绑定与转换",{"path":561,"title":562,"description":11},"\u002Fother\u002Fspring-series\u002Fspringmvc\u002Fspringmvc-exception","SpringMVC - 异常处理",{"path":564,"title":565,"description":11},"\u002Fother\u002Fspring-series\u002Fspringmvc\u002Fspringmvc-interceptor","SpringMVC - 拦截器",{"path":567,"title":568,"description":11},"\u002Fother\u002Fspring-series\u002Fspringmvc\u002Fspringmvc-introduction","SpringMVC - 简介与环境搭建",{"path":570,"title":571,"description":11},"\u002Fother\u002Fspring-series\u002Fspringmvc\u002Fspringmvc-request","SpringMVC - 请求处理",{"path":573,"title":574,"description":11},"\u002Fother\u002Fspring-series\u002Fspringmvc\u002Fspringmvc-response","SpringMVC - 响应处理",{"path":576,"title":577,"description":578},"\u002Fproject\u002Frocket-leaf\u002Farchitecture","项目架构","Rocket-Leaf 的目录结构、模块划分、数据流向，以及各层之间的依赖关系。",{"path":580,"title":581,"description":582},"\u002Fproject\u002Frocket-leaf\u002Fbackend-layers","后端分层设计","Rocket-Leaf 的 model \u002F rocketmq \u002F service 三层结构，以及服务之间的依赖关系与设计取舍。",{"path":584,"title":585,"description":586},"\u002Fproject\u002Frocket-leaf\u002Fclient-manager","RocketMQ 客户端管理器","AdminClientManager 的多客户端池、默认连接懒加载、自动重连重试的设计与实现。",{"path":588,"title":589,"description":590},"\u002Fproject\u002Frocket-leaf\u002Fencryption","连接信息加密存储","AES-256-GCM + SHA-256 字段级派生密钥的实现，以及如何在不破坏兼容性的前提下为历史明文数据做透明迁移。",{"path":592,"title":593,"description":594},"\u002Fproject\u002Frocket-leaf\u002Ffrontend","前端结构与类型绑定","React + Vite 目录组织、自动生成的 Wails 绑定、api 薄封装与自定义 hooks 的职责划分。",{"path":596,"title":597,"description":598},"\u002Fproject\u002Frocket-leaf","项目简介","Rocket-Leaf 是一款基于 Wails v3 构建的跨平台 RocketMQ 桌面管理客户端，Go 后端 + React 前端。本文档系列拆解它的架构与关键实现。",{"path":600,"title":601,"description":602},"\u002Fproject\u002Frocket-leaf\u002Fwails-v3","Wails v3 入门","Wails v3 的核心概念、Service 绑定机制，以及 Rocket-Leaf 是如何用它把 Go 后端和 React 前端打通的。",{"path":604,"title":605,"description":11},"\u002Ftutorials\u002Fcloud\u002Fdocker\u002Fdocker-basic","Docker - 入门基础",{"path":607,"title":608,"description":609},"\u002Ftutorials\u002Fcloud\u002Fdocker\u002Fdocker-compose","Docker - Compose","在部署应用时，常常使用到不止一个容器，那么在部署容器的时候就需要一个一个进行部署，这样的部署过程也相对来说比较繁琐复杂，也容易出问题，那么有没有一种更为简单的方法呢？",{"path":611,"title":612,"description":613},"\u002Ftutorials\u002Fcloud\u002Fdocker\u002Fdocker-container-connection","Docker - 容器互联","在上一个章节中我们学习了 Docker 容器的端口映射，可以将 Docker 容器和本地以及网络中的端口进行连接起来。",{"path":615,"title":616,"description":11},"\u002Ftutorials\u002Fcloud\u002Fdocker\u002Fdocker-dockerfile","Docker - Dockerfile",{"path":618,"title":619,"description":11},"\u002Ftutorials\u002Fcloud\u002Fdocker\u002Fdocker-helloworld","Docker - HelloWorld",{"path":621,"title":622,"description":11},"\u002Ftutorials\u002Fcloud\u002Fdocker\u002Fdocker-install","Docker - 安装",{"path":624,"title":625,"description":11},"\u002Ftutorials\u002Fcloud\u002Fdocker\u002Fdocker-introduce","Docker - 简介",{"path":627,"title":628,"description":11},"\u002Ftutorials\u002Fcloud\u002Fdocker\u002Fdocker-object","Docker - 镜像、容器、仓库",{"path":630,"title":631,"description":632},"\u002Ftutorials\u002Fcloud\u002Fdocker\u002Fdocker-warehouse","Docker - 仓库管理","仓库是集中存放资源的地方，代码仓库是存放代码的，那么Docker 中的仓库就是存放 Docker 镜像的。",{"path":634,"title":635,"description":636},"\u002Ftutorials\u002Fcloud\u002Fdocker\u002Fdocker-web-containers","Docker - WEB应用实例","在之前的章节中，仅对普通容器进行了演示，但在实际中常常使用到 Docker 容器中的 WEB 应用程序。",{"path":638,"title":639,"description":11},"\u002Ftutorials\u002Fcloud\u002Fkubernetes\u002Fk8s-config","Kubernetes - ConfigMap 与 Secret",{"path":641,"title":642,"description":11},"\u002Ftutorials\u002Fcloud\u002Fkubernetes\u002Fk8s-helm","Kubernetes - Helm 包管理",{"path":644,"title":645,"description":11},"\u002Ftutorials\u002Fcloud\u002Fkubernetes\u002Fk8s-install","Kubernetes - 集群安装",{"path":647,"title":648,"description":11},"\u002Ftutorials\u002Fcloud\u002Fkubernetes\u002Fk8s-introduction","Kubernetes - 简介与架构",{"path":650,"title":651,"description":11},"\u002Ftutorials\u002Fcloud\u002Fkubernetes\u002Fk8s-kubectl","Kubernetes - kubectl 命令行工具",{"path":653,"title":654,"description":11},"\u002Ftutorials\u002Fcloud\u002Fkubernetes\u002Fk8s-monitoring","Kubernetes - 监控与日志",{"path":656,"title":657,"description":11},"\u002Ftutorials\u002Fcloud\u002Fkubernetes\u002Fk8s-network-security","Kubernetes - 网络与安全",{"path":659,"title":660,"description":11},"\u002Ftutorials\u002Fcloud\u002Fkubernetes\u002Fk8s-service","Kubernetes - Service 与 Ingress",{"path":662,"title":663,"description":11},"\u002Ftutorials\u002Fcloud\u002Fkubernetes\u002Fk8s-storage","Kubernetes - 持久化存储",{"path":665,"title":666,"description":11},"\u002Ftutorials\u002Fcloud\u002Fkubernetes\u002Fk8s-workload","Kubernetes - 工作负载资源",{"path":668,"title":669,"description":11},"\u002Ftutorials\u002Fcloud\u002Flinux\u002Flinux-bash","Linux - Bash 基础语法",{"path":671,"title":672,"description":11},"\u002Ftutorials\u002Fcloud\u002Flinux\u002Flinux-file-directory","Linux - 文件与目录操作",{"path":674,"title":675,"description":11},"\u002Ftutorials\u002Fcloud\u002Flinux\u002Flinux-network","Linux - 网络配置",{"path":677,"title":678,"description":11},"\u002Ftutorials\u002Fcloud\u002Flinux\u002Flinux-package","Linux - 软件包管理",{"path":680,"title":681,"description":11},"\u002Ftutorials\u002Fcloud\u002Flinux\u002Flinux-process","Linux - 进程管理",{"path":683,"title":684,"description":11},"\u002Ftutorials\u002Fcloud\u002Flinux\u002Flinux-scripts","Linux - 常用脚本示例",{"path":686,"title":687,"description":11},"\u002Ftutorials\u002Fcloud\u002Flinux\u002Flinux-service","Linux - 服务管理",{"path":689,"title":690,"description":11},"\u002Ftutorials\u002Fcloud\u002Flinux\u002Flinux-user-permission","Linux - 用户与权限管理",{"path":692,"title":693,"description":11},"\u002Ftutorials\u002Fcloud\u002Fnginx\u002Fnginx-https","Nginx - HTTPS 配置",{"path":695,"title":696,"description":11},"\u002Ftutorials\u002Fcloud\u002Fnginx\u002Fnginx-install","Nginx - 安装与配置",{"path":698,"title":699,"description":11},"\u002Ftutorials\u002Fcloud\u002Fnginx\u002Fnginx-loadbalance","Nginx - 负载均衡",{"path":701,"title":702,"description":11},"\u002Ftutorials\u002Fcloud\u002Fnginx\u002Fnginx-optimization","Nginx - 性能优化",{"path":704,"title":705,"description":11},"\u002Ftutorials\u002Fcloud\u002Fnginx\u002Fnginx-proxy","Nginx - 反向代理",{"path":707,"title":708,"description":11},"\u002Ftutorials\u002Fcloud\u002Fnginx\u002Fnginx-static","Nginx - 静态资源服务",{"path":710,"title":711,"description":11},"\u002Ftutorials\u002Fcloud\u002Fnginx\u002Fnginx-vhost","Nginx - 虚拟主机配置",{"path":713,"title":714,"description":715},"\u002Ftutorials\u002Fdatabase\u002Fmysql\u002Fmysql-architecture","MySQL 高可用架构","主从复制、读写分离、分库分表。",{"path":717,"title":718,"description":719},"\u002Ftutorials\u002Fdatabase\u002Fmysql\u002Fmysql-index","MySQL 索引","索引是帮助 MySQL 高效获取数据的有序数据结构。",{"path":721,"title":722,"description":723},"\u002Ftutorials\u002Fdatabase\u002Fmysql\u002Fmysql-lock","MySQL 锁","锁用于解决并发访问时的数据一致性问题。",{"path":725,"title":726,"description":727},"\u002Ftutorials\u002Fdatabase\u002Fmysql\u002Fmysql-optimize","MySQL 性能优化","SQL 优化是后端开发必备技能。",{"path":729,"title":730,"description":731},"\u002Ftutorials\u002Fdatabase\u002Fmysql\u002Fmysql-transaction","MySQL 事务","事务是一组不可分割的操作，要么全部成功，要么全部失败。",{"path":733,"title":734,"description":735},"\u002Ftutorials\u002Fdatabase\u002Fmysql\u002Fsql-advanced","SQL 进阶","多表查询、子查询、函数、视图、存储过程。",{"path":737,"title":738,"description":739},"\u002Ftutorials\u002Fdatabase\u002Fmysql\u002Fsql-basic","SQL 基础","SQL（Structured Query Language）是操作关系型数据库的标准语言。",{"path":741,"title":742,"description":743},"\u002Ftutorials\u002Fdatabase\u002Fredis\u002Fredis-advanced","Redis 进阶功能","事务、发布订阅、Lua 脚本、Pipeline。",{"path":745,"title":746,"description":747},"\u002Ftutorials\u002Fdatabase\u002Fredis\u002Fredis-basic","Redis 基础","Redis 安装配置与基本命令。",{"path":749,"title":750,"description":751},"\u002Ftutorials\u002Fdatabase\u002Fredis\u002Fredis-cluster","Redis 高可用","主从复制、哨兵、Cluster 集群。",{"path":753,"title":754,"description":755},"\u002Ftutorials\u002Fdatabase\u002Fredis\u002Fredis-datatype","Redis 数据类型","Redis 5 种基本数据类型 + 4 种特殊类型。",{"path":757,"title":758,"description":759},"\u002Ftutorials\u002Fdatabase\u002Fredis\u002Fredis-optimize","Redis 性能优化","内存优化、缓存问题、最佳实践。",{"path":761,"title":762,"description":763},"\u002Ftutorials\u002Fdatabase\u002Fredis\u002Fredis-persistence","Redis 持久化","Redis 提供 RDB 和 AOF 两种持久化方式。",{"path":765,"title":766,"description":767},"\u002Ftutorials\u002Fdatabase\u002Fredis\u002Fredis-principle","Redis 底层原理","数据结构、线程模型、网络模型。",{"path":769,"title":770,"description":771},"\u002Ftutorials\u002Fdev-idea\u002Fdesign-patterns\u002Fbehaiver-patterns\u002Fobserver-pattern","观察者模式","观察者模式属于行为型模式，定义了对象之间的一对多的依赖关系，在这种模式中，当一个对象的状态发生变化时，所有依赖于它的对象都会得到通知，并且执行相关操作。观察者模式又被成为“发布—订阅模式”，即发布者发生改变后，会通知所有订阅者。",{"path":773,"title":774,"description":11},"\u002Ftutorials\u002Fdev-idea\u002Fdesign-patterns\u002Fcreate-patterns\u002Ffactory-pattern","工厂模式",{"path":776,"title":777,"description":778},"\u002Ftutorials\u002Fdev-idea\u002Fdesign-patterns\u002Fcreate-patterns\u002Fsingleton-pattern","单例模式","单例模式是最常用的设计模式之一，他可以保证在整个应用中，某个类只存在一个实例化对象，即全局使用到该类的只有一个对象，这种模式在需要限制某些类的实例数量时非常有用，通常全局只需要一个该对象即可，如一些配置文件映射对象、数据库连接对象等。",{"path":780,"title":781,"description":782},"\u002Ftutorials\u002Fdev-idea\u002Fdesign-patterns\u002Fstructural-patterns\u002Fadapter-pattern","适配器模式","适配器模式是一种结构型模式，可以将一个类的接口转换成客户端所期望的另一种接口，适配器模式可以帮助开发人员在不修改现有代码的情况下，将不兼容的类组合在一起。",{"path":784,"title":785,"description":786},"\u002Ftutorials\u002Fdev-tools\u002Fgit\u002Fgit-basic-operations","Git 创建版本库","在 Git 上创建版本库有两种方式，一种是直接拷贝远程 Git 仓库到本地，另外一种是我们自己创建本地的版本库。",{"path":788,"title":789,"description":11},"\u002Ftutorials\u002Fdev-tools\u002Fgit\u002Fgit-branch-manage","Git 分支管理",{"path":791,"title":792,"description":11},"\u002Ftutorials\u002Fdev-tools\u002Fgit\u002Fgit-content-operations","Git 仓库内容操作",{"path":794,"title":795,"description":11},"\u002Ftutorials\u002Fdev-tools\u002Fgit\u002Fgit-introduce-install","Git 介绍和安装",{"path":797,"title":798,"description":11},"\u002Ftutorials\u002Fdev-tools\u002Fgit\u002Fgit-remote-manage","Git 远程管理",{"path":800,"title":801,"description":11},"\u002Ftutorials\u002Fdev-tools\u002Fgit\u002Fgit-workspace-index-repo","Git 工作原理",{"path":803,"title":804,"description":11},"\u002Ftutorials\u002Fdev-tools\u002Fhomebrew","HomeBrew 教程",{"path":806,"title":807,"description":11},"\u002Ftutorials\u002Fdev-tools\u002Fidea\u002Fshortcuts","快捷键",{"path":809,"title":810,"description":11},"\u002Ftutorials\u002Fdev-tools\u002Fmaven\u002Fintroduce-install-config","Maven - 介绍、安装、配置",{"path":812,"title":813,"description":11},"\u002Ftutorials\u002Ffront-end\u002Fvue3\u002Fbasic-knowledge","2. 基础知识",{"path":815,"title":816,"description":817},"\u002Ftutorials\u002Ffront-end\u002Fvue3\u002Fcomponent-communication","9. 组件通信","在前面的章节内，介绍了 Vue 中最核心的内容——组件的介绍和使用，和 Java 等编程语言相反，组件并不近似于这些变成语言中的类，类可以通过类或者其实例化的对象来相互交互，但 Vue 组件之间的作用域是相互独立的，这就意味着不同组件之间的数据无法相互引用。",{"path":819,"title":820,"description":821},"\u002Ftutorials\u002Ffront-end\u002Fvue3\u002Fcomputed","4. 计算属性","虽然直接在模板中使用表达式方便，但是如果在模板中添加很多逻辑，会让模板变的臃肿且难维护，耦合度较高。有没有一种简单的方式来实现呢？答案是有的。",{"path":823,"title":824,"description":11},"\u002Ftutorials\u002Ffront-end\u002Fvue3\u002Fcreate-vue-project","1. 环境搭建及安装",{"path":826,"title":827,"description":828},"\u002Ftutorials\u002Ffront-end\u002Fvue3\u002Flife-cycle","6. 生命周期","生命周期是指组件从创建、挂载、更新到销毁的整个过程中所经历的一系列阶段。在 Vue 中，每个组件都有自己的生命周期，可以通过生命周期钩子函数来监听和处理组件在不同阶段的行为和状态。",{"path":830,"title":831,"description":11},"\u002Ftutorials\u002Ffront-end\u002Fvue3\u002Fother-api","10. 其他 API",{"path":833,"title":834,"description":11},"\u002Ftutorials\u002Ffront-end\u002Fvue3\u002Fpinia","8. Pinia",{"path":836,"title":837,"description":11},"\u002Ftutorials\u002Ffront-end\u002Fvue3\u002Frouter","7. 路由",{"path":839,"title":840,"description":11},"\u002Ftutorials\u002Ffront-end\u002Fvue3\u002Ftemplate-grammar","3. 指令及模板语法",{"path":842,"title":843,"description":11},"\u002Ftutorials\u002Ffront-end\u002Fvue3\u002Fvue3-new-component","11. Vue3 新组件",{"path":845,"title":846,"description":847},"\u002Ftutorials\u002Ffront-end\u002Fvue3\u002Fwatch","5. 监视","Watch 是 Vue 提供的一个用于监视响应式数据变化并执行相应操作的 API，能够对响应式数据的变化做出一些操作的功能。Vue3 中的 Watch 支持多种用法，包括监视响应式对象、ref 对象、数组、函数等。",{"path":849,"title":850,"description":11},"\u002Ftutorials\u002Fmq\u002Fkafka\u002Fkafka-introduction","Kafka 简介与安装",{"path":852,"title":853,"description":11},"\u002Ftutorials\u002Fmq\u002Fkafka\u002Fkafka-producer-consumer","Kafka 生产者与消费者",{"path":855,"title":856,"description":857},"\u002Ftutorials\u002Fmq\u002Fkafka\u002Fkafka-springboot","Spring Boot 整合 Kafka","Spring Kafka 提供了对 Apache Kafka 的便捷集成。",{"path":859,"title":860,"description":861},"\u002Ftutorials\u002Fmq\u002Frabbitmq\u002Frabbitmq-exchange","RabbitMQ Exchange 详解","Exchange（交换机）是 RabbitMQ 的核心组件，负责接收生产者发送的消息，并根据规则将消息路由到一个或多个队列。",{"path":863,"title":864,"description":11},"\u002Ftutorials\u002Fmq\u002Frabbitmq\u002Frabbitmq-introduction","RabbitMQ 简介与安装",{"path":866,"title":867,"description":868},"\u002Ftutorials\u002Fmq\u002Frabbitmq\u002Frabbitmq-reliability","RabbitMQ 消息可靠性","消息可靠性是消息队列的核心要求，RabbitMQ 提供了多种机制来保证消息不丢失。",{"path":870,"title":871,"description":872},"\u002Ftutorials\u002Fmq\u002Frabbitmq\u002Frabbitmq-springboot","Spring Boot 整合 RabbitMQ","Spring AMQP 提供了对 RabbitMQ 的便捷集成，大大简化了开发工作。",{"path":874,"title":875,"description":11},"\u002Ftutorials\u002Fmq\u002Frocketmq\u002Frocketmq-client","RocketMQ 客户端使用",{"path":877,"title":878,"description":11},"\u002Ftutorials\u002Fmq\u002Frocketmq\u002Frocketmq-concepts","RocketMQ 核心概念",{"path":880,"title":881,"description":11},"\u002Ftutorials\u002Fmq\u002Frocketmq\u002Frocketmq-installation","RocketMQ 安装部署",{"path":883,"title":884,"description":885},"\u002Ftutorials\u002Fmq\u002Frocketmq\u002Frocketmq-message-type","RocketMQ 消息类型","RocketMQ 支持多种消息类型，满足不同业务场景需求。",{"id":887,"title":46,"body":888,"description":47,"extension":2873,"meta":2874,"navigation":1084,"path":45,"seo":2875,"stem":2876,"__hash__":2877},"docs\u002Fai\u002Ffundamentals\u002Fml-basics.md",{"type":889,"value":890,"toc":2841},"minimark",[891,895,899,903,906,909,977,982,985,988,1005,1244,1248,1251,1254,1274,1434,1438,1441,1444,1470,1474,1477,1481,1484,1487,1498,1636,1640,1643,1653,1729,1733,1736,1828,1831,1886,1890,1893,1969,1973,1977,1980,1983,1998,2001,2004,2007,2078,2157,2160,2163,2208,2211,2214,2218,2221,2227,2233,2247,2251,2254,2259,2263,2280,2288,2292,2295,2429,2432,2436,2439,2443,2446,2582,2585,2591,2594,2597,2600,2660,2781,2784,2787,2790,2834,2837],[892,893,894],"h2",{"id":894},"什么是机器学习",[896,897,898],"p",{},"机器学习（Machine Learning, ML）是人工智能的核心分支，其本质是让计算机从数据中自动学习规律，并利用学到的规律对新数据做出预测或决策，而无需显式编程每一条规则。",[900,901,902],"tip",{},"\n对于开发者来说，机器学习可以理解为：**用数据代替硬编码规则**。传统编程是 `输入 + 规则 → 输出`，而机器学习是 `输入 + 输出 → 规则`。\n",[892,904,905],{"id":905},"机器学习的三大范式",[896,907,908],{},"根据训练数据的标注方式和学习目标，机器学习主要分为三大类：",[910,911,912,931],"table",{},[913,914,915],"thead",{},[916,917,918,922,925,928],"tr",{},[919,920,921],"th",{},"范式",[919,923,924],{},"数据特点",[919,926,927],{},"目标",[919,929,930],{},"典型应用",[932,933,934,949,963],"tbody",{},[916,935,936,940,943,946],{},[937,938,939],"td",{},"监督学习",[937,941,942],{},"有标签数据（X → Y）",[937,944,945],{},"学习输入到输出的映射",[937,947,948],{},"分类、回归",[916,950,951,954,957,960],{},[937,952,953],{},"无监督学习",[937,955,956],{},"无标签数据（仅 X）",[937,958,959],{},"发现数据内在结构",[937,961,962],{},"聚类、降维",[916,964,965,968,971,974],{},[937,966,967],{},"强化学习",[937,969,970],{},"环境反馈（奖励信号）",[937,972,973],{},"最大化累积奖励",[937,975,976],{},"游戏AI、机器人控制",[978,979,981],"h3",{"id":980},"监督学习supervised-learning","监督学习（Supervised Learning）",[896,983,984],{},"监督学习是最常用的机器学习方式。训练数据包含输入特征和对应的标签（正确答案），模型通过学习输入与标签之间的关系来进行预测。",[896,986,987],{},"监督学习又分为两类任务：",[989,990,991,999],"ul",{},[992,993,994,998],"li",{},[995,996,997],"strong",{},"分类（Classification）","：预测离散类别。例如：判断邮件是否为垃圾邮件、图片中是猫还是狗。",[992,1000,1001,1004],{},[995,1002,1003],{},"回归（Regression）","：预测连续数值。例如：预测房价、股票价格。",[1006,1007,1011],"pre",{"className":1008,"code":1009,"language":1010,"meta":11,"style":11},"language-python shiki shiki-themes github-light github-light github-dark","# 监督学习示例：使用 scikit-learn 训练一个分类模型\nfrom sklearn.datasets import load_iris\nfrom sklearn.model_selection import train_test_split\nfrom sklearn.tree import DecisionTreeClassifier\nfrom sklearn.metrics import accuracy_score\n\n# 加载数据（带标签）\ndata = load_iris()\nX, y = data.data, data.target\n\n# 划分训练集和测试集\nX_train, X_test, y_train, y_test = train_test_split(X, y, test_size=0.2, random_state=42)\n\n# 训练模型\nmodel = DecisionTreeClassifier()\nmodel.fit(X_train, y_train)\n\n# 预测并评估\ny_pred = model.predict(X_test)\nprint(f\"准确率: {accuracy_score(y_test, y_pred):.2f}\")\n","python",[1012,1013,1014,1023,1040,1053,1066,1079,1086,1092,1104,1115,1120,1126,1161,1166,1172,1183,1189,1194,1200,1211],"code",{"__ignoreMap":11},[1015,1016,1019],"span",{"class":1017,"line":1018},"line",1,[1015,1020,1022],{"class":1021},"sCsY4","# 监督学习示例：使用 scikit-learn 训练一个分类模型\n",[1015,1024,1026,1030,1034,1037],{"class":1017,"line":1025},2,[1015,1027,1029],{"class":1028},"s8jYJ","from",[1015,1031,1033],{"class":1032},"sxrX7"," sklearn.datasets ",[1015,1035,1036],{"class":1028},"import",[1015,1038,1039],{"class":1032}," load_iris\n",[1015,1041,1043,1045,1048,1050],{"class":1017,"line":1042},3,[1015,1044,1029],{"class":1028},[1015,1046,1047],{"class":1032}," sklearn.model_selection ",[1015,1049,1036],{"class":1028},[1015,1051,1052],{"class":1032}," train_test_split\n",[1015,1054,1056,1058,1061,1063],{"class":1017,"line":1055},4,[1015,1057,1029],{"class":1028},[1015,1059,1060],{"class":1032}," sklearn.tree ",[1015,1062,1036],{"class":1028},[1015,1064,1065],{"class":1032}," DecisionTreeClassifier\n",[1015,1067,1069,1071,1074,1076],{"class":1017,"line":1068},5,[1015,1070,1029],{"class":1028},[1015,1072,1073],{"class":1032}," sklearn.metrics ",[1015,1075,1036],{"class":1028},[1015,1077,1078],{"class":1032}," accuracy_score\n",[1015,1080,1082],{"class":1017,"line":1081},6,[1015,1083,1085],{"emptyLinePlaceholder":1084},true,"\n",[1015,1087,1089],{"class":1017,"line":1088},7,[1015,1090,1091],{"class":1021},"# 加载数据（带标签）\n",[1015,1093,1095,1098,1101],{"class":1017,"line":1094},8,[1015,1096,1097],{"class":1032},"data ",[1015,1099,1100],{"class":1028},"=",[1015,1102,1103],{"class":1032}," load_iris()\n",[1015,1105,1107,1110,1112],{"class":1017,"line":1106},9,[1015,1108,1109],{"class":1032},"X, y ",[1015,1111,1100],{"class":1028},[1015,1113,1114],{"class":1032}," data.data, data.target\n",[1015,1116,1118],{"class":1017,"line":1117},10,[1015,1119,1085],{"emptyLinePlaceholder":1084},[1015,1121,1123],{"class":1017,"line":1122},11,[1015,1124,1125],{"class":1021},"# 划分训练集和测试集\n",[1015,1127,1129,1132,1134,1137,1141,1143,1147,1150,1153,1155,1158],{"class":1017,"line":1128},12,[1015,1130,1131],{"class":1032},"X_train, X_test, y_train, y_test ",[1015,1133,1100],{"class":1028},[1015,1135,1136],{"class":1032}," train_test_split(X, y, ",[1015,1138,1140],{"class":1139},"sP4rz","test_size",[1015,1142,1100],{"class":1028},[1015,1144,1146],{"class":1145},"sBjJW","0.2",[1015,1148,1149],{"class":1032},", ",[1015,1151,1152],{"class":1139},"random_state",[1015,1154,1100],{"class":1028},[1015,1156,1157],{"class":1145},"42",[1015,1159,1160],{"class":1032},")\n",[1015,1162,1164],{"class":1017,"line":1163},13,[1015,1165,1085],{"emptyLinePlaceholder":1084},[1015,1167,1169],{"class":1017,"line":1168},14,[1015,1170,1171],{"class":1021},"# 训练模型\n",[1015,1173,1175,1178,1180],{"class":1017,"line":1174},15,[1015,1176,1177],{"class":1032},"model ",[1015,1179,1100],{"class":1028},[1015,1181,1182],{"class":1032}," DecisionTreeClassifier()\n",[1015,1184,1186],{"class":1017,"line":1185},16,[1015,1187,1188],{"class":1032},"model.fit(X_train, y_train)\n",[1015,1190,1192],{"class":1017,"line":1191},17,[1015,1193,1085],{"emptyLinePlaceholder":1084},[1015,1195,1197],{"class":1017,"line":1196},18,[1015,1198,1199],{"class":1021},"# 预测并评估\n",[1015,1201,1203,1206,1208],{"class":1017,"line":1202},19,[1015,1204,1205],{"class":1032},"y_pred ",[1015,1207,1100],{"class":1028},[1015,1209,1210],{"class":1032}," model.predict(X_test)\n",[1015,1212,1214,1217,1220,1223,1227,1230,1233,1236,1239,1242],{"class":1017,"line":1213},20,[1015,1215,1216],{"class":1145},"print",[1015,1218,1219],{"class":1032},"(",[1015,1221,1222],{"class":1028},"f",[1015,1224,1226],{"class":1225},"sIIMD","\"准确率: ",[1015,1228,1229],{"class":1145},"{",[1015,1231,1232],{"class":1032},"accuracy_score(y_test, y_pred)",[1015,1234,1235],{"class":1028},":.2f",[1015,1237,1238],{"class":1145},"}",[1015,1240,1241],{"class":1225},"\"",[1015,1243,1160],{"class":1032},[978,1245,1247],{"id":1246},"无监督学习unsupervised-learning","无监督学习（Unsupervised Learning）",[896,1249,1250],{},"无监督学习的训练数据没有标签，模型需要自行发现数据中的模式和结构。",[896,1252,1253],{},"常见任务包括：",[989,1255,1256,1262,1268],{},[992,1257,1258,1261],{},[995,1259,1260],{},"聚类（Clustering）","：将相似的数据分组，如客户分群、文档主题聚类。",[992,1263,1264,1267],{},[995,1265,1266],{},"降维（Dimensionality Reduction）","：在保留关键信息的前提下减少特征维度，如 PCA、t-SNE。",[992,1269,1270,1273],{},[995,1271,1272],{},"异常检测（Anomaly Detection）","：识别与大多数数据显著不同的样本。",[1006,1275,1277],{"className":1008,"code":1276,"language":1010,"meta":11,"style":11},"# 无监督学习示例：K-Means 聚类\nfrom sklearn.cluster import KMeans\nimport numpy as np\n\n# 模拟数据（无标签）\nX = np.random.randn(300, 2)\n\n# 聚类为 3 组\nkmeans = KMeans(n_clusters=3, random_state=42)\nlabels = kmeans.fit_predict(X)\n\nprint(f\"聚类中心:\\n{kmeans.cluster_centers_}\")\nprint(f\"各簇样本数: {np.bincount(labels)}\")\n",[1012,1278,1279,1284,1296,1309,1313,1318,1338,1342,1347,1375,1385,1389,1412],{"__ignoreMap":11},[1015,1280,1281],{"class":1017,"line":1018},[1015,1282,1283],{"class":1021},"# 无监督学习示例：K-Means 聚类\n",[1015,1285,1286,1288,1291,1293],{"class":1017,"line":1025},[1015,1287,1029],{"class":1028},[1015,1289,1290],{"class":1032}," sklearn.cluster ",[1015,1292,1036],{"class":1028},[1015,1294,1295],{"class":1032}," KMeans\n",[1015,1297,1298,1300,1303,1306],{"class":1017,"line":1042},[1015,1299,1036],{"class":1028},[1015,1301,1302],{"class":1032}," numpy ",[1015,1304,1305],{"class":1028},"as",[1015,1307,1308],{"class":1032}," np\n",[1015,1310,1311],{"class":1017,"line":1055},[1015,1312,1085],{"emptyLinePlaceholder":1084},[1015,1314,1315],{"class":1017,"line":1068},[1015,1316,1317],{"class":1021},"# 模拟数据（无标签）\n",[1015,1319,1320,1323,1325,1328,1331,1333,1336],{"class":1017,"line":1081},[1015,1321,1322],{"class":1032},"X ",[1015,1324,1100],{"class":1028},[1015,1326,1327],{"class":1032}," np.random.randn(",[1015,1329,1330],{"class":1145},"300",[1015,1332,1149],{"class":1032},[1015,1334,1335],{"class":1145},"2",[1015,1337,1160],{"class":1032},[1015,1339,1340],{"class":1017,"line":1088},[1015,1341,1085],{"emptyLinePlaceholder":1084},[1015,1343,1344],{"class":1017,"line":1094},[1015,1345,1346],{"class":1021},"# 聚类为 3 组\n",[1015,1348,1349,1352,1354,1357,1360,1362,1365,1367,1369,1371,1373],{"class":1017,"line":1106},[1015,1350,1351],{"class":1032},"kmeans ",[1015,1353,1100],{"class":1028},[1015,1355,1356],{"class":1032}," KMeans(",[1015,1358,1359],{"class":1139},"n_clusters",[1015,1361,1100],{"class":1028},[1015,1363,1364],{"class":1145},"3",[1015,1366,1149],{"class":1032},[1015,1368,1152],{"class":1139},[1015,1370,1100],{"class":1028},[1015,1372,1157],{"class":1145},[1015,1374,1160],{"class":1032},[1015,1376,1377,1380,1382],{"class":1017,"line":1117},[1015,1378,1379],{"class":1032},"labels ",[1015,1381,1100],{"class":1028},[1015,1383,1384],{"class":1032}," kmeans.fit_predict(X)\n",[1015,1386,1387],{"class":1017,"line":1122},[1015,1388,1085],{"emptyLinePlaceholder":1084},[1015,1390,1391,1393,1395,1397,1400,1403,1406,1408,1410],{"class":1017,"line":1128},[1015,1392,1216],{"class":1145},[1015,1394,1219],{"class":1032},[1015,1396,1222],{"class":1028},[1015,1398,1399],{"class":1225},"\"聚类中心:",[1015,1401,1402],{"class":1145},"\\n{",[1015,1404,1405],{"class":1032},"kmeans.cluster_centers_",[1015,1407,1238],{"class":1145},[1015,1409,1241],{"class":1225},[1015,1411,1160],{"class":1032},[1015,1413,1414,1416,1418,1420,1423,1425,1428,1430,1432],{"class":1017,"line":1163},[1015,1415,1216],{"class":1145},[1015,1417,1219],{"class":1032},[1015,1419,1222],{"class":1028},[1015,1421,1422],{"class":1225},"\"各簇样本数: ",[1015,1424,1229],{"class":1145},[1015,1426,1427],{"class":1032},"np.bincount(labels)",[1015,1429,1238],{"class":1145},[1015,1431,1241],{"class":1225},[1015,1433,1160],{"class":1032},[978,1435,1437],{"id":1436},"强化学习reinforcement-learning","强化学习（Reinforcement Learning）",[896,1439,1440],{},"强化学习中，智能体（Agent）通过与环境交互获取奖励信号，目标是学习一个策略来最大化长期累积奖励。",[896,1442,1443],{},"核心要素：",[989,1445,1446,1452,1458,1464],{},[992,1447,1448,1451],{},[995,1449,1450],{},"状态（State）","：环境的当前情况",[992,1453,1454,1457],{},[995,1455,1456],{},"动作（Action）","：智能体可以执行的操作",[992,1459,1460,1463],{},[995,1461,1462],{},"奖励（Reward）","：执行动作后获得的反馈",[992,1465,1466,1469],{},[995,1467,1468],{},"策略（Policy）","：从状态到动作的映射",[1471,1472,1473],"note",{},"\n强化学习的典型应用包括 AlphaGo、自动驾驶、游戏 AI 等。与监督学习不同，强化学习不需要预先标注的数据，而是通过试错来学习。\n",[892,1475,1476],{"id":1476},"常用机器学习算法",[978,1478,1480],{"id":1479},"线性回归linear-regression","线性回归（Linear Regression）",[896,1482,1483],{},"线性回归是最基础的回归算法，假设输出与输入之间存在线性关系：",[896,1485,1486],{},"$$y = w_1 x_1 + w_2 x_2 + ... + w_n x_n + b$$",[896,1488,1489,1490,1493,1494,1497],{},"模型通过最小化均方误差（MSE）来学习参数 ",[1012,1491,1492],{},"w"," 和 ",[1012,1495,1496],{},"b","。",[1006,1499,1501],{"className":1008,"code":1500,"language":1010,"meta":11,"style":11},"from sklearn.linear_model import LinearRegression\nfrom sklearn.metrics import mean_squared_error\n\nmodel = LinearRegression()\nmodel.fit(X_train, y_train)\n\ny_pred = model.predict(X_test)\nmse = mean_squared_error(y_test, y_pred)\nprint(f\"均方误差: {mse:.4f}\")\nprint(f\"模型系数: {model.coef_}\")\nprint(f\"截距: {model.intercept_:.4f}\")\n",[1012,1502,1503,1515,1526,1530,1539,1543,1547,1555,1565,1590,1612],{"__ignoreMap":11},[1015,1504,1505,1507,1510,1512],{"class":1017,"line":1018},[1015,1506,1029],{"class":1028},[1015,1508,1509],{"class":1032}," sklearn.linear_model ",[1015,1511,1036],{"class":1028},[1015,1513,1514],{"class":1032}," LinearRegression\n",[1015,1516,1517,1519,1521,1523],{"class":1017,"line":1025},[1015,1518,1029],{"class":1028},[1015,1520,1073],{"class":1032},[1015,1522,1036],{"class":1028},[1015,1524,1525],{"class":1032}," mean_squared_error\n",[1015,1527,1528],{"class":1017,"line":1042},[1015,1529,1085],{"emptyLinePlaceholder":1084},[1015,1531,1532,1534,1536],{"class":1017,"line":1055},[1015,1533,1177],{"class":1032},[1015,1535,1100],{"class":1028},[1015,1537,1538],{"class":1032}," LinearRegression()\n",[1015,1540,1541],{"class":1017,"line":1068},[1015,1542,1188],{"class":1032},[1015,1544,1545],{"class":1017,"line":1081},[1015,1546,1085],{"emptyLinePlaceholder":1084},[1015,1548,1549,1551,1553],{"class":1017,"line":1088},[1015,1550,1205],{"class":1032},[1015,1552,1100],{"class":1028},[1015,1554,1210],{"class":1032},[1015,1556,1557,1560,1562],{"class":1017,"line":1094},[1015,1558,1559],{"class":1032},"mse ",[1015,1561,1100],{"class":1028},[1015,1563,1564],{"class":1032}," mean_squared_error(y_test, y_pred)\n",[1015,1566,1567,1569,1571,1573,1576,1578,1581,1584,1586,1588],{"class":1017,"line":1106},[1015,1568,1216],{"class":1145},[1015,1570,1219],{"class":1032},[1015,1572,1222],{"class":1028},[1015,1574,1575],{"class":1225},"\"均方误差: ",[1015,1577,1229],{"class":1145},[1015,1579,1580],{"class":1032},"mse",[1015,1582,1583],{"class":1028},":.4f",[1015,1585,1238],{"class":1145},[1015,1587,1241],{"class":1225},[1015,1589,1160],{"class":1032},[1015,1591,1592,1594,1596,1598,1601,1603,1606,1608,1610],{"class":1017,"line":1117},[1015,1593,1216],{"class":1145},[1015,1595,1219],{"class":1032},[1015,1597,1222],{"class":1028},[1015,1599,1600],{"class":1225},"\"模型系数: ",[1015,1602,1229],{"class":1145},[1015,1604,1605],{"class":1032},"model.coef_",[1015,1607,1238],{"class":1145},[1015,1609,1241],{"class":1225},[1015,1611,1160],{"class":1032},[1015,1613,1614,1616,1618,1620,1623,1625,1628,1630,1632,1634],{"class":1017,"line":1122},[1015,1615,1216],{"class":1145},[1015,1617,1219],{"class":1032},[1015,1619,1222],{"class":1028},[1015,1621,1622],{"class":1225},"\"截距: ",[1015,1624,1229],{"class":1145},[1015,1626,1627],{"class":1032},"model.intercept_",[1015,1629,1583],{"class":1028},[1015,1631,1238],{"class":1145},[1015,1633,1241],{"class":1225},[1015,1635,1160],{"class":1032},[978,1637,1639],{"id":1638},"决策树decision-tree","决策树（Decision Tree）",[896,1641,1642],{},"决策树通过一系列 if-else 规则对数据进行分割，形成树状结构。每个内部节点代表一个特征判断，叶子节点代表预测结果。",[896,1644,1645,1648,1649,1652],{},[995,1646,1647],{},"优点","：可解释性强、无需特征缩放、能处理非线性关系。\n",[995,1650,1651],{},"缺点","：容易过拟合、对数据变化敏感。",[1006,1654,1656],{"className":1008,"code":1655,"language":1010,"meta":11,"style":11},"from sklearn.tree import DecisionTreeClassifier, export_text\n\nmodel = DecisionTreeClassifier(max_depth=3)\nmodel.fit(X_train, y_train)\n\n# 打印决策树规则，直观查看模型学到了什么\ntree_rules = export_text(model, feature_names=data.feature_names)\nprint(tree_rules)\n",[1012,1657,1658,1669,1673,1691,1695,1699,1704,1722],{"__ignoreMap":11},[1015,1659,1660,1662,1664,1666],{"class":1017,"line":1018},[1015,1661,1029],{"class":1028},[1015,1663,1060],{"class":1032},[1015,1665,1036],{"class":1028},[1015,1667,1668],{"class":1032}," DecisionTreeClassifier, export_text\n",[1015,1670,1671],{"class":1017,"line":1025},[1015,1672,1085],{"emptyLinePlaceholder":1084},[1015,1674,1675,1677,1679,1682,1685,1687,1689],{"class":1017,"line":1042},[1015,1676,1177],{"class":1032},[1015,1678,1100],{"class":1028},[1015,1680,1681],{"class":1032}," DecisionTreeClassifier(",[1015,1683,1684],{"class":1139},"max_depth",[1015,1686,1100],{"class":1028},[1015,1688,1364],{"class":1145},[1015,1690,1160],{"class":1032},[1015,1692,1693],{"class":1017,"line":1055},[1015,1694,1188],{"class":1032},[1015,1696,1697],{"class":1017,"line":1068},[1015,1698,1085],{"emptyLinePlaceholder":1084},[1015,1700,1701],{"class":1017,"line":1081},[1015,1702,1703],{"class":1021},"# 打印决策树规则，直观查看模型学到了什么\n",[1015,1705,1706,1709,1711,1714,1717,1719],{"class":1017,"line":1088},[1015,1707,1708],{"class":1032},"tree_rules ",[1015,1710,1100],{"class":1028},[1015,1712,1713],{"class":1032}," export_text(model, ",[1015,1715,1716],{"class":1139},"feature_names",[1015,1718,1100],{"class":1028},[1015,1720,1721],{"class":1032},"data.feature_names)\n",[1015,1723,1724,1726],{"class":1017,"line":1094},[1015,1725,1216],{"class":1145},[1015,1727,1728],{"class":1032},"(tree_rules)\n",[978,1730,1732],{"id":1731},"支持向量机svm","支持向量机（SVM）",[896,1734,1735],{},"SVM 的核心思想是找到一个超平面，使得不同类别之间的间隔最大化。通过核函数（Kernel Trick）可以处理非线性可分的数据。",[1006,1737,1739],{"className":1008,"code":1738,"language":1010,"meta":11,"style":11},"from sklearn.svm import SVC\n\n# 使用 RBF 核函数\nmodel = SVC(kernel='rbf', C=1.0, gamma='scale')\nmodel.fit(X_train, y_train)\nprint(f\"准确率: {model.score(X_test, y_test):.2f}\")\n",[1012,1740,1741,1753,1757,1762,1801,1805],{"__ignoreMap":11},[1015,1742,1743,1745,1748,1750],{"class":1017,"line":1018},[1015,1744,1029],{"class":1028},[1015,1746,1747],{"class":1032}," sklearn.svm ",[1015,1749,1036],{"class":1028},[1015,1751,1752],{"class":1145}," SVC\n",[1015,1754,1755],{"class":1017,"line":1025},[1015,1756,1085],{"emptyLinePlaceholder":1084},[1015,1758,1759],{"class":1017,"line":1042},[1015,1760,1761],{"class":1021},"# 使用 RBF 核函数\n",[1015,1763,1764,1766,1768,1771,1774,1776,1779,1781,1784,1786,1789,1791,1794,1796,1799],{"class":1017,"line":1055},[1015,1765,1177],{"class":1032},[1015,1767,1100],{"class":1028},[1015,1769,1770],{"class":1032}," SVC(",[1015,1772,1773],{"class":1139},"kernel",[1015,1775,1100],{"class":1028},[1015,1777,1778],{"class":1225},"'rbf'",[1015,1780,1149],{"class":1032},[1015,1782,1783],{"class":1139},"C",[1015,1785,1100],{"class":1028},[1015,1787,1788],{"class":1145},"1.0",[1015,1790,1149],{"class":1032},[1015,1792,1793],{"class":1139},"gamma",[1015,1795,1100],{"class":1028},[1015,1797,1798],{"class":1225},"'scale'",[1015,1800,1160],{"class":1032},[1015,1802,1803],{"class":1017,"line":1068},[1015,1804,1188],{"class":1032},[1015,1806,1807,1809,1811,1813,1815,1817,1820,1822,1824,1826],{"class":1017,"line":1081},[1015,1808,1216],{"class":1145},[1015,1810,1219],{"class":1032},[1015,1812,1222],{"class":1028},[1015,1814,1226],{"class":1225},[1015,1816,1229],{"class":1145},[1015,1818,1819],{"class":1032},"model.score(X_test, y_test)",[1015,1821,1235],{"class":1028},[1015,1823,1238],{"class":1145},[1015,1825,1241],{"class":1225},[1015,1827,1160],{"class":1032},[896,1829,1830],{},"常用核函数：",[910,1832,1833,1846],{},[913,1834,1835],{},[916,1836,1837,1840,1843],{},[919,1838,1839],{},"核函数",[919,1841,1842],{},"适用场景",[919,1844,1845],{},"参数",[932,1847,1848,1860,1873],{},[916,1849,1850,1855,1858],{},[937,1851,1852],{},[1012,1853,1854],{},"linear",[937,1856,1857],{},"线性可分数据",[937,1859,1783],{},[916,1861,1862,1867,1870],{},[937,1863,1864],{},[1012,1865,1866],{},"rbf",[937,1868,1869],{},"通用非线性数据（默认）",[937,1871,1872],{},"C, gamma",[916,1874,1875,1880,1883],{},[937,1876,1877],{},[1012,1878,1879],{},"poly",[937,1881,1882],{},"多项式关系数据",[937,1884,1885],{},"C, degree",[978,1887,1889],{"id":1888},"k-近邻knn","K 近邻（KNN）",[896,1891,1892],{},"KNN 是一种基于实例的学习方法。对于新样本，找到训练集中距离最近的 K 个样本，通过投票（分类）或平均（回归）来预测。",[1006,1894,1896],{"className":1008,"code":1895,"language":1010,"meta":11,"style":11},"from sklearn.neighbors import KNeighborsClassifier\n\nmodel = KNeighborsClassifier(n_neighbors=5, metric='euclidean')\nmodel.fit(X_train, y_train)\nprint(f\"准确率: {model.score(X_test, y_test):.2f}\")\n",[1012,1897,1898,1910,1914,1943,1947],{"__ignoreMap":11},[1015,1899,1900,1902,1905,1907],{"class":1017,"line":1018},[1015,1901,1029],{"class":1028},[1015,1903,1904],{"class":1032}," sklearn.neighbors ",[1015,1906,1036],{"class":1028},[1015,1908,1909],{"class":1032}," KNeighborsClassifier\n",[1015,1911,1912],{"class":1017,"line":1025},[1015,1913,1085],{"emptyLinePlaceholder":1084},[1015,1915,1916,1918,1920,1923,1926,1928,1931,1933,1936,1938,1941],{"class":1017,"line":1042},[1015,1917,1177],{"class":1032},[1015,1919,1100],{"class":1028},[1015,1921,1922],{"class":1032}," KNeighborsClassifier(",[1015,1924,1925],{"class":1139},"n_neighbors",[1015,1927,1100],{"class":1028},[1015,1929,1930],{"class":1145},"5",[1015,1932,1149],{"class":1032},[1015,1934,1935],{"class":1139},"metric",[1015,1937,1100],{"class":1028},[1015,1939,1940],{"class":1225},"'euclidean'",[1015,1942,1160],{"class":1032},[1015,1944,1945],{"class":1017,"line":1055},[1015,1946,1188],{"class":1032},[1015,1948,1949,1951,1953,1955,1957,1959,1961,1963,1965,1967],{"class":1017,"line":1068},[1015,1950,1216],{"class":1145},[1015,1952,1219],{"class":1032},[1015,1954,1222],{"class":1028},[1015,1956,1226],{"class":1225},[1015,1958,1229],{"class":1145},[1015,1960,1819],{"class":1032},[1015,1962,1235],{"class":1028},[1015,1964,1238],{"class":1145},[1015,1966,1241],{"class":1225},[1015,1968,1160],{"class":1032},[1970,1971,1972],"warning",{},"\nKNN 在高维数据上性能较差（维度灾难），且预测速度慢，因为每次预测都需要计算与所有训练样本的距离。在生产环境中需谨慎使用。\n",[978,1974,1976],{"id":1975},"聚类算法k-means","聚类算法（K-Means）",[896,1978,1979],{},"K-Means 是最经典的聚类算法，将数据划分为 K 个簇，使得每个样本到其所属簇中心的距离之和最小。",[896,1981,1982],{},"算法步骤：",[1984,1985,1986,1989,1992,1995],"ol",{},[992,1987,1988],{},"随机初始化 K 个聚类中心",[992,1990,1991],{},"将每个样本分配到最近的聚类中心",[992,1993,1994],{},"重新计算每个簇的中心",[992,1996,1997],{},"重复步骤 2-3 直到收敛",[892,1999,2000],{"id":2000},"模型评估指标",[896,2002,2003],{},"选择正确的评估指标对模型开发至关重要。",[978,2005,2006],{"id":2006},"分类指标",[910,2008,2009,2021],{},[913,2010,2011],{},[916,2012,2013,2016,2019],{},[919,2014,2015],{},"指标",[919,2017,2018],{},"公式",[919,2020,1842],{},[932,2022,2023,2034,2045,2056,2067],{},[916,2024,2025,2028,2031],{},[937,2026,2027],{},"准确率（Accuracy）",[937,2029,2030],{},"正确预测数 \u002F 总样本数",[937,2032,2033],{},"类别均衡时",[916,2035,2036,2039,2042],{},[937,2037,2038],{},"精确率（Precision）",[937,2040,2041],{},"TP \u002F (TP + FP)",[937,2043,2044],{},"关注假阳性代价时",[916,2046,2047,2050,2053],{},[937,2048,2049],{},"召回率（Recall）",[937,2051,2052],{},"TP \u002F (TP + FN)",[937,2054,2055],{},"关注假阴性代价时",[916,2057,2058,2061,2064],{},[937,2059,2060],{},"F1 Score",[937,2062,2063],{},"2 × P × R \u002F (P + R)",[937,2065,2066],{},"精确率与召回率的平衡",[916,2068,2069,2072,2075],{},[937,2070,2071],{},"AUC-ROC",[937,2073,2074],{},"ROC 曲线下面积",[937,2076,2077],{},"二分类综合评估",[1006,2079,2081],{"className":1008,"code":2080,"language":1010,"meta":11,"style":11},"from sklearn.metrics import classification_report, confusion_matrix\n\ny_pred = model.predict(X_test)\n\n# 打印详细分类报告\nprint(classification_report(y_test, y_pred, target_names=data.target_names))\n\n# 混淆矩阵\nprint(\"混淆矩阵:\")\nprint(confusion_matrix(y_test, y_pred))\n",[1012,2082,2083,2094,2098,2106,2110,2115,2130,2134,2139,2150],{"__ignoreMap":11},[1015,2084,2085,2087,2089,2091],{"class":1017,"line":1018},[1015,2086,1029],{"class":1028},[1015,2088,1073],{"class":1032},[1015,2090,1036],{"class":1028},[1015,2092,2093],{"class":1032}," classification_report, confusion_matrix\n",[1015,2095,2096],{"class":1017,"line":1025},[1015,2097,1085],{"emptyLinePlaceholder":1084},[1015,2099,2100,2102,2104],{"class":1017,"line":1042},[1015,2101,1205],{"class":1032},[1015,2103,1100],{"class":1028},[1015,2105,1210],{"class":1032},[1015,2107,2108],{"class":1017,"line":1055},[1015,2109,1085],{"emptyLinePlaceholder":1084},[1015,2111,2112],{"class":1017,"line":1068},[1015,2113,2114],{"class":1021},"# 打印详细分类报告\n",[1015,2116,2117,2119,2122,2125,2127],{"class":1017,"line":1081},[1015,2118,1216],{"class":1145},[1015,2120,2121],{"class":1032},"(classification_report(y_test, y_pred, ",[1015,2123,2124],{"class":1139},"target_names",[1015,2126,1100],{"class":1028},[1015,2128,2129],{"class":1032},"data.target_names))\n",[1015,2131,2132],{"class":1017,"line":1088},[1015,2133,1085],{"emptyLinePlaceholder":1084},[1015,2135,2136],{"class":1017,"line":1094},[1015,2137,2138],{"class":1021},"# 混淆矩阵\n",[1015,2140,2141,2143,2145,2148],{"class":1017,"line":1106},[1015,2142,1216],{"class":1145},[1015,2144,1219],{"class":1032},[1015,2146,2147],{"class":1225},"\"混淆矩阵:\"",[1015,2149,1160],{"class":1032},[1015,2151,2152,2154],{"class":1017,"line":1117},[1015,2153,1216],{"class":1145},[1015,2155,2156],{"class":1032},"(confusion_matrix(y_test, y_pred))\n",[1471,2158,2159],{},"\n当数据类别严重不均衡时（如欺诈检测中正常交易远多于欺诈交易），准确率会产生误导。此时应更关注精确率、召回率和 F1 Score。\n",[978,2161,2162],{"id":2162},"回归指标",[910,2164,2165,2174],{},[913,2166,2167],{},[916,2168,2169,2171],{},[919,2170,2015],{},[919,2172,2173],{},"说明",[932,2175,2176,2184,2192,2200],{},[916,2177,2178,2181],{},[937,2179,2180],{},"MSE（均方误差）",[937,2182,2183],{},"预测误差的平方均值，对大误差敏感",[916,2185,2186,2189],{},[937,2187,2188],{},"RMSE（均方根误差）",[937,2190,2191],{},"MSE 的平方根，与目标值同量纲",[916,2193,2194,2197],{},[937,2195,2196],{},"MAE（平均绝对误差）",[937,2198,2199],{},"预测误差的绝对值均值，对异常值鲁棒",[916,2201,2202,2205],{},[937,2203,2204],{},"R²（决定系数）",[937,2206,2207],{},"模型解释方差的比例，1 为完美，0 为基线",[892,2209,2210],{"id":2210},"过拟合与欠拟合",[896,2212,2213],{},"这是机器学习中最核心的概念之一，直接决定模型的泛化能力。",[978,2215,2217],{"id":2216},"欠拟合underfitting","欠拟合（Underfitting）",[896,2219,2220],{},"模型过于简单，无法捕捉数据中的规律，在训练集和测试集上表现都差。",[896,2222,2223,2226],{},[995,2224,2225],{},"原因","：模型复杂度不够、特征不足、训练不充分。",[896,2228,2229,2232],{},[995,2230,2231],{},"解决方法","：",[989,2234,2235,2238,2241,2244],{},[992,2236,2237],{},"使用更复杂的模型",[992,2239,2240],{},"增加特征或进行特征工程",[992,2242,2243],{},"减少正则化强度",[992,2245,2246],{},"增加训练轮次",[978,2248,2250],{"id":2249},"过拟合overfitting","过拟合（Overfitting）",[896,2252,2253],{},"模型过于复杂，在训练集上表现优秀但在测试集上表现差——模型记住了训练数据中的噪声而非真正的规律。",[896,2255,2256,2258],{},[995,2257,2225],{},"：模型过于复杂、训练数据不足、训练时间过长。",[896,2260,2261,2232],{},[995,2262,2231],{},[989,2264,2265,2268,2271,2274,2277],{},[992,2266,2267],{},"增加训练数据",[992,2269,2270],{},"使用正则化（L1\u002FL2）",[992,2272,2273],{},"降低模型复杂度（如限制决策树深度）",[992,2275,2276],{},"使用 Dropout（深度学习）",[992,2278,2279],{},"早停（Early Stopping）",[1006,2281,2286],{"className":2282,"code":2284,"language":2285},[2283],"language-text","训练误差  ↓ ████████████████████████████████░░░░░░  低\n测试误差  ↓ ████████████░░░░░░░░░████████████████  先降后升\n                   ↑                ↑\n               最佳复杂度        过拟合开始\n          欠拟合区域    |    过拟合区域\n","text",[1012,2287,2284],{"__ignoreMap":11},[892,2289,2291],{"id":2290},"训练集测试集划分","训练集\u002F测试集划分",[896,2293,2294],{},"为了评估模型在未见数据上的表现，必须将数据划分为训练集和测试集。",[1006,2296,2298],{"className":1008,"code":2297,"language":1010,"meta":11,"style":11},"from sklearn.model_selection import train_test_split\n\n# 常见的划分比例：80\u002F20 或 70\u002F30\nX_train, X_test, y_train, y_test = train_test_split(\n    X, y,\n    test_size=0.2,       # 20% 作为测试集\n    random_state=42,     # 固定随机种子，保证可复现\n    stratify=y           # 分层抽样，保持类别比例一致\n)\n\nprint(f\"训练集大小: {len(X_train)}\")\nprint(f\"测试集大小: {len(X_test)}\")\n",[1012,2299,2300,2310,2314,2319,2328,2333,2348,2363,2376,2380,2384,2407],{"__ignoreMap":11},[1015,2301,2302,2304,2306,2308],{"class":1017,"line":1018},[1015,2303,1029],{"class":1028},[1015,2305,1047],{"class":1032},[1015,2307,1036],{"class":1028},[1015,2309,1052],{"class":1032},[1015,2311,2312],{"class":1017,"line":1025},[1015,2313,1085],{"emptyLinePlaceholder":1084},[1015,2315,2316],{"class":1017,"line":1042},[1015,2317,2318],{"class":1021},"# 常见的划分比例：80\u002F20 或 70\u002F30\n",[1015,2320,2321,2323,2325],{"class":1017,"line":1055},[1015,2322,1131],{"class":1032},[1015,2324,1100],{"class":1028},[1015,2326,2327],{"class":1032}," train_test_split(\n",[1015,2329,2330],{"class":1017,"line":1068},[1015,2331,2332],{"class":1032},"    X, y,\n",[1015,2334,2335,2338,2340,2342,2345],{"class":1017,"line":1081},[1015,2336,2337],{"class":1139},"    test_size",[1015,2339,1100],{"class":1028},[1015,2341,1146],{"class":1145},[1015,2343,2344],{"class":1032},",       ",[1015,2346,2347],{"class":1021},"# 20% 作为测试集\n",[1015,2349,2350,2353,2355,2357,2360],{"class":1017,"line":1088},[1015,2351,2352],{"class":1139},"    random_state",[1015,2354,1100],{"class":1028},[1015,2356,1157],{"class":1145},[1015,2358,2359],{"class":1032},",     ",[1015,2361,2362],{"class":1021},"# 固定随机种子，保证可复现\n",[1015,2364,2365,2368,2370,2373],{"class":1017,"line":1094},[1015,2366,2367],{"class":1139},"    stratify",[1015,2369,1100],{"class":1028},[1015,2371,2372],{"class":1032},"y           ",[1015,2374,2375],{"class":1021},"# 分层抽样，保持类别比例一致\n",[1015,2377,2378],{"class":1017,"line":1106},[1015,2379,1160],{"class":1032},[1015,2381,2382],{"class":1017,"line":1117},[1015,2383,1085],{"emptyLinePlaceholder":1084},[1015,2385,2386,2388,2390,2392,2395,2398,2401,2403,2405],{"class":1017,"line":1122},[1015,2387,1216],{"class":1145},[1015,2389,1219],{"class":1032},[1015,2391,1222],{"class":1028},[1015,2393,2394],{"class":1225},"\"训练集大小: ",[1015,2396,2397],{"class":1145},"{len",[1015,2399,2400],{"class":1032},"(X_train)",[1015,2402,1238],{"class":1145},[1015,2404,1241],{"class":1225},[1015,2406,1160],{"class":1032},[1015,2408,2409,2411,2413,2415,2418,2420,2423,2425,2427],{"class":1017,"line":1128},[1015,2410,1216],{"class":1145},[1015,2412,1219],{"class":1032},[1015,2414,1222],{"class":1028},[1015,2416,2417],{"class":1225},"\"测试集大小: ",[1015,2419,2397],{"class":1145},[1015,2421,2422],{"class":1032},"(X_test)",[1015,2424,1238],{"class":1145},[1015,2426,1241],{"class":1225},[1015,2428,1160],{"class":1032},[1970,2430,2431],{},"\n**绝对不要**用测试集来调参或选择模型。如果需要调参，应额外划分出一个验证集（Validation Set），或使用交叉验证。测试集应该只在最终评估时使用一次。\n",[892,2433,2435],{"id":2434},"交叉验证cross-validation","交叉验证（Cross-Validation）",[896,2437,2438],{},"交叉验证通过多次划分数据来更可靠地评估模型性能，避免因单次随机划分导致的评估偏差。",[978,2440,2442],{"id":2441},"k-折交叉验证k-fold-cv","K 折交叉验证（K-Fold CV）",[896,2444,2445],{},"将数据分为 K 份，每次用其中 1 份作为验证集，其余 K-1 份作为训练集，重复 K 次取平均。",[1006,2447,2449],{"className":1008,"code":2448,"language":1010,"meta":11,"style":11},"from sklearn.model_selection import cross_val_score\n\nmodel = DecisionTreeClassifier(max_depth=5)\n\n# 5 折交叉验证\nscores = cross_val_score(model, X, y, cv=5, scoring='accuracy')\n\nprint(f\"每折准确率: {scores}\")\nprint(f\"平均准确率: {scores.mean():.4f} ± {scores.std():.4f}\")\n",[1012,2450,2451,2462,2466,2482,2486,2491,2520,2524,2546],{"__ignoreMap":11},[1015,2452,2453,2455,2457,2459],{"class":1017,"line":1018},[1015,2454,1029],{"class":1028},[1015,2456,1047],{"class":1032},[1015,2458,1036],{"class":1028},[1015,2460,2461],{"class":1032}," cross_val_score\n",[1015,2463,2464],{"class":1017,"line":1025},[1015,2465,1085],{"emptyLinePlaceholder":1084},[1015,2467,2468,2470,2472,2474,2476,2478,2480],{"class":1017,"line":1042},[1015,2469,1177],{"class":1032},[1015,2471,1100],{"class":1028},[1015,2473,1681],{"class":1032},[1015,2475,1684],{"class":1139},[1015,2477,1100],{"class":1028},[1015,2479,1930],{"class":1145},[1015,2481,1160],{"class":1032},[1015,2483,2484],{"class":1017,"line":1055},[1015,2485,1085],{"emptyLinePlaceholder":1084},[1015,2487,2488],{"class":1017,"line":1068},[1015,2489,2490],{"class":1021},"# 5 折交叉验证\n",[1015,2492,2493,2496,2498,2501,2504,2506,2508,2510,2513,2515,2518],{"class":1017,"line":1081},[1015,2494,2495],{"class":1032},"scores ",[1015,2497,1100],{"class":1028},[1015,2499,2500],{"class":1032}," cross_val_score(model, X, y, ",[1015,2502,2503],{"class":1139},"cv",[1015,2505,1100],{"class":1028},[1015,2507,1930],{"class":1145},[1015,2509,1149],{"class":1032},[1015,2511,2512],{"class":1139},"scoring",[1015,2514,1100],{"class":1028},[1015,2516,2517],{"class":1225},"'accuracy'",[1015,2519,1160],{"class":1032},[1015,2521,2522],{"class":1017,"line":1088},[1015,2523,1085],{"emptyLinePlaceholder":1084},[1015,2525,2526,2528,2530,2532,2535,2537,2540,2542,2544],{"class":1017,"line":1094},[1015,2527,1216],{"class":1145},[1015,2529,1219],{"class":1032},[1015,2531,1222],{"class":1028},[1015,2533,2534],{"class":1225},"\"每折准确率: ",[1015,2536,1229],{"class":1145},[1015,2538,2539],{"class":1032},"scores",[1015,2541,1238],{"class":1145},[1015,2543,1241],{"class":1225},[1015,2545,1160],{"class":1032},[1015,2547,2548,2550,2552,2554,2557,2559,2562,2564,2566,2569,2571,2574,2576,2578,2580],{"class":1017,"line":1106},[1015,2549,1216],{"class":1145},[1015,2551,1219],{"class":1032},[1015,2553,1222],{"class":1028},[1015,2555,2556],{"class":1225},"\"平均准确率: ",[1015,2558,1229],{"class":1145},[1015,2560,2561],{"class":1032},"scores.mean()",[1015,2563,1583],{"class":1028},[1015,2565,1238],{"class":1145},[1015,2567,2568],{"class":1225}," ± ",[1015,2570,1229],{"class":1145},[1015,2572,2573],{"class":1032},"scores.std()",[1015,2575,1583],{"class":1028},[1015,2577,1238],{"class":1145},[1015,2579,1241],{"class":1225},[1015,2581,1160],{"class":1032},[978,2583,2584],{"id":2584},"实际开发中的数据划分策略",[1006,2586,2589],{"className":2587,"code":2588,"language":2285},[2283],"原始数据集\n├── 训练集（70%）──── 用于 K 折交叉验证 ──── 调参 & 选模型\n├── 验证集（15%）──── 监控训练过程（可选）\n└── 测试集（15%）──── 最终一次性评估\n",[1012,2590,2588],{"__ignoreMap":11},[892,2592,2593],{"id":2593},"特征工程基础",[896,2595,2596],{},"特征工程是提升模型性能最有效的手段之一，往往比更换算法更有效。",[978,2598,2599],{"id":2599},"常见操作",[910,2601,2602,2614],{},[913,2603,2604],{},[916,2605,2606,2609,2611],{},[919,2607,2608],{},"操作",[919,2610,2173],{},[919,2612,2613],{},"示例",[932,2615,2616,2627,2638,2649],{},[916,2617,2618,2621,2624],{},[937,2619,2620],{},"特征缩放",[937,2622,2623],{},"将特征统一到相同尺度",[937,2625,2626],{},"StandardScaler, MinMaxScaler",[916,2628,2629,2632,2635],{},[937,2630,2631],{},"独热编码",[937,2633,2634],{},"将类别特征转为数值",[937,2636,2637],{},"OneHotEncoder",[916,2639,2640,2643,2646],{},[937,2641,2642],{},"缺失值处理",[937,2644,2645],{},"填充或删除缺失数据",[937,2647,2648],{},"SimpleImputer",[916,2650,2651,2654,2657],{},[937,2652,2653],{},"特征选择",[937,2655,2656],{},"选择最重要的特征",[937,2658,2659],{},"SelectKBest",[1006,2661,2663],{"className":1008,"code":2662,"language":1010,"meta":11,"style":11},"from sklearn.preprocessing import StandardScaler\nfrom sklearn.pipeline import Pipeline\n\n# 使用 Pipeline 组织预处理和模型训练\npipeline = Pipeline([\n    ('scaler', StandardScaler()),          # 标准化\n    ('classifier', SVC(kernel='rbf'))      # SVM 分类器\n])\n\npipeline.fit(X_train, y_train)\nprint(f\"准确率: {pipeline.score(X_test, y_test):.2f}\")\n",[1012,2664,2665,2677,2689,2693,2698,2708,2722,2744,2749,2753,2758],{"__ignoreMap":11},[1015,2666,2667,2669,2672,2674],{"class":1017,"line":1018},[1015,2668,1029],{"class":1028},[1015,2670,2671],{"class":1032}," sklearn.preprocessing ",[1015,2673,1036],{"class":1028},[1015,2675,2676],{"class":1032}," StandardScaler\n",[1015,2678,2679,2681,2684,2686],{"class":1017,"line":1025},[1015,2680,1029],{"class":1028},[1015,2682,2683],{"class":1032}," sklearn.pipeline ",[1015,2685,1036],{"class":1028},[1015,2687,2688],{"class":1032}," Pipeline\n",[1015,2690,2691],{"class":1017,"line":1042},[1015,2692,1085],{"emptyLinePlaceholder":1084},[1015,2694,2695],{"class":1017,"line":1055},[1015,2696,2697],{"class":1021},"# 使用 Pipeline 组织预处理和模型训练\n",[1015,2699,2700,2703,2705],{"class":1017,"line":1068},[1015,2701,2702],{"class":1032},"pipeline ",[1015,2704,1100],{"class":1028},[1015,2706,2707],{"class":1032}," Pipeline([\n",[1015,2709,2710,2713,2716,2719],{"class":1017,"line":1081},[1015,2711,2712],{"class":1032},"    (",[1015,2714,2715],{"class":1225},"'scaler'",[1015,2717,2718],{"class":1032},", StandardScaler()),          ",[1015,2720,2721],{"class":1021},"# 标准化\n",[1015,2723,2724,2726,2729,2732,2734,2736,2738,2741],{"class":1017,"line":1088},[1015,2725,2712],{"class":1032},[1015,2727,2728],{"class":1225},"'classifier'",[1015,2730,2731],{"class":1032},", SVC(",[1015,2733,1773],{"class":1139},[1015,2735,1100],{"class":1028},[1015,2737,1778],{"class":1225},[1015,2739,2740],{"class":1032},"))      ",[1015,2742,2743],{"class":1021},"# SVM 分类器\n",[1015,2745,2746],{"class":1017,"line":1094},[1015,2747,2748],{"class":1032},"])\n",[1015,2750,2751],{"class":1017,"line":1106},[1015,2752,1085],{"emptyLinePlaceholder":1084},[1015,2754,2755],{"class":1017,"line":1117},[1015,2756,2757],{"class":1032},"pipeline.fit(X_train, y_train)\n",[1015,2759,2760,2762,2764,2766,2768,2770,2773,2775,2777,2779],{"class":1017,"line":1122},[1015,2761,1216],{"class":1145},[1015,2763,1219],{"class":1032},[1015,2765,1222],{"class":1028},[1015,2767,1226],{"class":1225},[1015,2769,1229],{"class":1145},[1015,2771,2772],{"class":1032},"pipeline.score(X_test, y_test)",[1015,2774,1235],{"class":1028},[1015,2776,1238],{"class":1145},[1015,2778,1241],{"class":1225},[1015,2780,1160],{"class":1032},[900,2782,2783],{},"\n使用 `Pipeline` 可以将预处理步骤和模型训练封装在一起，避免数据泄露（Data Leakage），同时让代码更清晰、更易于维护。这是 scikit-learn 中推荐的最佳实践。\n",[892,2785,2786],{"id":2786},"小结",[896,2788,2789],{},"机器学习的核心工作流程：",[1984,2791,2792,2798,2804,2810,2816,2822,2828],{},[992,2793,2794,2797],{},[995,2795,2796],{},"定义问题","：明确是分类还是回归、监督还是无监督",[992,2799,2800,2803],{},[995,2801,2802],{},"准备数据","：收集、清洗、特征工程",[992,2805,2806,2809],{},[995,2807,2808],{},"选择模型","：根据问题类型和数据特点选择算法",[992,2811,2812,2815],{},[995,2813,2814],{},"训练模型","：用训练集拟合模型",[992,2817,2818,2821],{},[995,2819,2820],{},"评估模型","：用交叉验证和测试集评估性能",[992,2823,2824,2827],{},[995,2825,2826],{},"调优迭代","：调整超参数、改进特征、尝试不同算法",[992,2829,2830,2833],{},[995,2831,2832],{},"部署上线","：将模型集成到应用中",[896,2835,2836],{},"掌握这些基础概念后，你可以继续学习深度学习和神经网络，进入更高级的 AI 领域。",[2838,2839,2840],"style",{},"html pre.shiki code .sCsY4, html code.shiki .sCsY4{--shiki-light:#6A737D;--shiki-default:#6A737D;--shiki-dark:#6A737D}html pre.shiki code .s8jYJ, html code.shiki .s8jYJ{--shiki-light:#D73A49;--shiki-default:#D73A49;--shiki-dark:#F97583}html pre.shiki code .sxrX7, html code.shiki .sxrX7{--shiki-light:#24292E;--shiki-default:#24292E;--shiki-dark:#E1E4E8}html pre.shiki code .sP4rz, html code.shiki .sP4rz{--shiki-light:#E36209;--shiki-default:#E36209;--shiki-dark:#FFAB70}html pre.shiki code .sBjJW, html code.shiki .sBjJW{--shiki-light:#005CC5;--shiki-default:#005CC5;--shiki-dark:#79B8FF}html pre.shiki code .sIIMD, html code.shiki .sIIMD{--shiki-light:#032F62;--shiki-default:#032F62;--shiki-dark:#9ECBFF}html .light .shiki span {color: var(--shiki-light);background: var(--shiki-light-bg);font-style: var(--shiki-light-font-style);font-weight: var(--shiki-light-font-weight);text-decoration: var(--shiki-light-text-decoration);}html.light .shiki span {color: var(--shiki-light);background: var(--shiki-light-bg);font-style: var(--shiki-light-font-style);font-weight: var(--shiki-light-font-weight);text-decoration: var(--shiki-light-text-decoration);}html .default .shiki span {color: var(--shiki-default);background: var(--shiki-default-bg);font-style: var(--shiki-default-font-style);font-weight: var(--shiki-default-font-weight);text-decoration: var(--shiki-default-text-decoration);}html .shiki span {color: var(--shiki-default);background: var(--shiki-default-bg);font-style: var(--shiki-default-font-style);font-weight: var(--shiki-default-font-weight);text-decoration: var(--shiki-default-text-decoration);}html .dark .shiki span {color: var(--shiki-dark);background: var(--shiki-dark-bg);font-style: var(--shiki-dark-font-style);font-weight: var(--shiki-dark-font-weight);text-decoration: var(--shiki-dark-text-decoration);}html.dark .shiki span {color: var(--shiki-dark);background: var(--shiki-dark-bg);font-style: var(--shiki-dark-font-style);font-weight: var(--shiki-dark-font-weight);text-decoration: var(--shiki-dark-text-decoration);}",{"title":11,"searchDepth":1025,"depth":1025,"links":2842},[2843,2844,2849,2856,2860,2864,2865,2869,2872],{"id":894,"depth":1025,"text":894},{"id":905,"depth":1025,"text":905,"children":2845},[2846,2847,2848],{"id":980,"depth":1042,"text":981},{"id":1246,"depth":1042,"text":1247},{"id":1436,"depth":1042,"text":1437},{"id":1476,"depth":1025,"text":1476,"children":2850},[2851,2852,2853,2854,2855],{"id":1479,"depth":1042,"text":1480},{"id":1638,"depth":1042,"text":1639},{"id":1731,"depth":1042,"text":1732},{"id":1888,"depth":1042,"text":1889},{"id":1975,"depth":1042,"text":1976},{"id":2000,"depth":1025,"text":2000,"children":2857},[2858,2859],{"id":2006,"depth":1042,"text":2006},{"id":2162,"depth":1042,"text":2162},{"id":2210,"depth":1025,"text":2210,"children":2861},[2862,2863],{"id":2216,"depth":1042,"text":2217},{"id":2249,"depth":1042,"text":2250},{"id":2290,"depth":1025,"text":2291},{"id":2434,"depth":1025,"text":2435,"children":2866},[2867,2868],{"id":2441,"depth":1042,"text":2442},{"id":2584,"depth":1042,"text":2584},{"id":2593,"depth":1025,"text":2593,"children":2870},[2871],{"id":2599,"depth":1042,"text":2599},{"id":2786,"depth":1025,"text":2786},"md",{},{"title":46,"description":47},"ai\u002Ffundamentals\u002Fml-basics","772zy0G0h7WD-cl4wvikIgrgGuSnUR_d7VQlSUZWruk",1775474634393]