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

00 | 从零打造Claude Code:AI编程Agent完整解析(一)——引言篇

从零打造Claude Code:AI编程Agent完整解析(一)——引言篇声明:📝 作者:甜城瑞庄的核桃(ZMJ)原创学习笔记,欢迎分享,但请保留作者信息及原文链接哦~本系列文章深度解析如何从零开始构建一个类似Claude Code的AI编程助手,涵盖Agent循环、工具系统、提示词工程、权限安全等核心技术。本文为系列第一篇,介绍项目背景、架构设计和快速上手。📌 文章导读项目背景: 为什么要从零造一个Claude Code核心概念: Agent-first架构的本质技术架构: 系统组件与职责划分快速开始: 5分钟运行你的coding agent学习路径: 系列文章概览一、为什么从零打造Claude Code?1.1 AI编程的三个进化阶段AI辅助编程经历了质的飞跃:阶段1: 代码补全 (GitHub Copilot) ↓ 只能补全代码片段,无法执行操作 阶段2: 聊天助手 (Cursor Chat) ↓ 可以给出建议,但模型不能自己验证结果 阶段3: 自主Agent (Claude Code) ✓ 模型可以执行工具、验证结果、自动修复错误关键区别: 前两个阶段模型只能"建议",无法"行动"。Claude Code则是真正的自主Agent。1.2 真实场景演示假设你对Claude Code说:“给这个项目加用户注册功能”它会自动执行以下操作:🔍 搜索现有路由定义📖 读取数据库模型代码✍️ 创建handler文件🔗 注册路由🧪 编写测试用例▶️ 运行npm test👀 检查测试结果🐛 发现失败,分析原因🔧 修复代码🔁 再次测试…循环直至成功这就是受控工具循环Agent的威力:模型是决策者: 决定下一步做什么代码是执行环境: 提供工具和循环框架1.3 Agent-first架构的本质传统程序vs Agent程序:# 传统程序: 代码逻辑决定行为ifcondition:do_action_a()else:do_action_b()# Agent程序: 模型决定行为whileTrue:response=call_model()ifresponse.has_tool_calls():results=execute_tools(response.tool_calls)feed_back_to_model(results)continueifresponse.is_text_only():break# 模型决定任务完成核心差异:传统程序: 程序员预先定义所有分支逻辑Agent程序: 模型实时决策,代码只提供基础设施1.4 为什么不直接读Claude Code源码?Claude Code开源快照包含:50万行TypeScript代码66+工具实现React/Ink TUI框架MCP协议支持OAuth认证系统多层抽象和边界情况处理直接阅读容易迷失在实现细节中。我们的方法:用**~3400行代码**复现核心能力保留最小必要组件每一步对照真实源码讲解就像造卡丁车来理解汽车原理二、核心概念速览2.1 Agent Loop (思考-行动-观察循环)┌─────────────────────────────────┐ │ 用户请求: "添加用户注册功能" │ └────────────┬────────────────────┘ │ ▼ ┌────────────────┐ │ 调用模型思考 │ └────┬───────────┘ │ ▼ ┌─────────────────────┐ │ 模型返回工具调用请求 │ │ [read_file, grep] │ └────┬────────────────┘ │ ▼ ┌──────────────┐ │ 执行工具 │ └────┬─────────┘ │ ▼ ┌──────────────────┐ │ 工具结果反馈模型 │ └────┬─────────────┘ │ ▼ ┌──────────────────┐ │ 模型继续思考... │ └────┬─────────────┘ │ ▼ 循环直到模型不再调用工具2.2 工具系统工具是Agent与现实世界交互的桥梁:// System Prompt中描述工具{name:"read_file",description:"读取文件内容",parameters:{file_path:"string"}}// 模型返回工具调用{type:"tool_use",name:"read_file",input:{file_path:"/src/agent.ts"}}// 代码执行工具constresult=fs.readFileSync(input.file_path,'utf-8')// 结果反馈模型{type:"tool_result",content:"文件内容..."}2.3 上下文工程挑战:上下文窗口有限(200K tokens)复杂任务可能跑几十轮如何在有限空间内保留关键信息?解决方案: 4级压缩流水线Level 0: 工具执行时截断 (保留头尾) ↓ Level 1: 预算动态缩减 (利用率50%触发) ↓ Level 2: 替换过时工具结果 (Snip) ↓ Level 3: 空闲时激进清理 (Microcompact) ↓ Level 4: 全量摘要压缩 (Autocompact, 85%触发)2.4 System Prompt每次API调用前组装的"任务说明书":System Prompt组成:-身份定位:"你是Claude Code,一个AI编程助手"-系统环境

相关文章:

00 | 从零打造Claude Code:AI编程Agent完整解析(一)——引言篇

从零打造Claude Code:AI编程Agent完整解析(一)——引言篇 声明: 📝 作者:甜城瑞庄的核桃(ZMJ) 原创学习笔记,欢迎分享,但请保留作者信息及原文链接哦~ 本系列文章深度解析如何从零开始构建一个类似Claude Code的AI编程助手,涵盖Agent循环、工具系统、提示词工程、权限…...

融合 PSO 的改进鲸鱼优化算法(PSO‑ImWOA)无人机三维航迹规划研究(Python代码实现)

💥💥💞💞欢迎来到本博客❤️❤️💥💥 🏆博主优势:🌞🌞🌞博客内容尽量做到思维缜密,逻辑清晰,为了方便读者。 ⛳️座右铭&a…...

.NET 9容器化避坑清单,12个导致K8s滚动更新失败的隐藏陷阱及修复代码

第一章:.NET 9容器化部署的核心演进与K8s适配全景 .NET 9标志着微软在云原生交付范式上的关键跃迁——其运行时、SDK与基础镜像深度重构,为容器化场景注入原生优化能力。与以往版本相比,.NET 9默认启用AOT(Ahead-of-Time&#xff…...

律所主任如何高效监控所里几百个案子的进度

结论律所主任想要高效监控所里几百个案子的进度,纯靠人工询问或 Excel 表格是无法实现的,必须依托数字化管理工具(如"案件云"系统)。通过建立可视化案件看板、设置关键节点与期限自动化预警,以及实现全所云端…...

Mojo+Python混合编程避坑手册:5个致命安装错误及对应修复命令(附官方源码验证)

第一章:MojoPython混合编程避坑手册:5个致命安装错误及对应修复命令(附官方源码验证) Mojo 是 Modular 官方推出的高性能编程语言,原生兼容 Python 语法,但其工具链对环境依赖极为敏感。初学者在配置 MojoP…...

OpenClaw多模型对比:Phi-3-vision-128k-instruct与纯文本模型任务效率实测

OpenClaw多模型对比:Phi-3-vision-128k-instruct与纯文本模型任务效率实测 1. 测试背景与目标 最近在尝试用OpenClaw搭建个人自动化工作流时,遇到了一个实际需求:需要定期从特定网页抓取内容并生成分析报告。这个任务既包含图文信息提取&am…...

2025届最火的五大AI论文网站横评

Ai论文网站排名(开题报告、文献综述、降aigc率、降重综合对比) TOP1. 千笔AI TOP2. aipasspaper TOP3. 清北论文 TOP4. 豆包 TOP5. kimi TOP6. deepseek 在生成式人工智能技术于学术写作里被广泛施行当下,维普平台正式推出了AIGC内容检…...

Apache APISIX Dashboard API权限绕过导致RCE(CVE-2021-45232)复现

Apache APISIX是一个动态、实时、高性能API网关,而Apache APISIX Dashboard是一个配套的前端面板。 Apache APISIX Dashboard 2.10.1版本前存在两个API/apisix/admin/migrate/export和/apisix/admin/migrate/import,他们没有经过droplet框架的权限验证&…...

2025届必备的六大AI辅助写作平台横评

Ai论文网站排名(开题报告、文献综述、降aigc率、降重综合对比) TOP1. 千笔AI TOP2. aipasspaper TOP3. 清北论文 TOP4. 豆包 TOP5. kimi TOP6. deepseek 进行学术写作以及内容创作之际,使文本的AI生成痕迹得以降低,这是提升…...

AI 时代,计算机专业学生该怎么学?昂

整体排查思路 我们的目标是验证以下三个环节是否正常: 登录成功时:服务器是否正确生成了Session并返回了包含正确 JSESSIONID的Cookie给浏览器。 浏览器端:浏览器是否成功接收并存储了该Cookie。 后续请求:浏览器在执行查询等操作…...

VsCode插件避坑指南:我为什么卸载了这些热门插件(附替代方案)

VSCode插件避坑指南:我为什么卸载了这些热门插件(附替代方案) 第一次打开VSCode的插件市场时,那种感觉就像走进了一家琳琅满目的糖果店——每个插件都包装精美,下载量动辄百万,五星好评如潮。但当我真正开始…...

不满意Oh My Zsh启动卡顿,来试试Starship吧城

pagehelper整合 引入依赖com.github.pagehelperpagehelper-spring-boot-starter2.1.0compile编写代码 GetMapping("/list/{pageNo}") public PageInfo findAll(PathVariable int pageNo) {// 设置当前页码和每页显示的条数PageHelper.startPage(pageNo, 10);// 查询数…...

Leetcode只二叉树中序遍历(python解法)

1.题目描述 示例 1: 输入:root [1,null,2,3] 输出:[1,3,2]示例 2: 输入:root [] 输出:[]示例 3: 输入:root [1] 输出:[1]2.解决方法: 中序遍历就是先遍历左子树然后…...

工业模拟量传感器抗干扰设计与实践

1. 工业现场模拟量传感器的干扰挑战在工业自动化领域,模拟量传感器就像一位敏感的"听诊器",它能精确捕捉生产过程中的各种物理量变化。但现实中的工业环境往往充斥着各种"噪音"——大功率电机启停产生的电磁干扰、变频器工作时的谐波…...

靠两台电脑,月入10万,一个中年人的实战分享

阿阳到底是谁?凭什么能做到 月入10万 ?先跟大家说个实话啊,我不是什么大牛,也没啥 光 环。我就是个普通人,普通的家庭,普通的脑子,普通的起点。唯一不普通的,可能就是——我辞职得比…...

代码之外周刊(第期):当技术让一切趋同,我们还剩什么?克

1. 前言 本文详细介绍如何使用 kylin v10 iso 文件构建出 docker image,docker 版本为 20.10.7。 2. 构建 yum 离线源 2.1. 挂载 ISO 文件 mount Kylin-Server-V10-GFB-Release-030-ARM64.iso /media 2.2. 添加离线 repo 文件 在/etc/yum.repos.d/下创建kylin-local…...

龙芯k - 走马观碑组MPU驱动移植谖

先回顾:三次握手(建立连接)核心流程(实际版) 为了让挥手流程衔接更顺畅,咱们先快速回顾三次握手的实际核心,避免上下文脱节: 第一步(客户端→服务器)&#xf…...

Windows环境SonarQube与SonarScanner实战:从零搭建代码质量守护体系

1. 为什么你的项目需要SonarQube? 每次提交代码前,你是不是总在担心那些隐藏的Bug会悄悄溜进生产环境?我见过太多团队在深夜被紧急报警叫醒,原因往往只是一行没处理好的空指针异常。SonarQube就像个24小时值班的代码质检员&#x…...

Arduino TFT库:寄存器级驱动与双芯片兼容设计

1. 项目概述TFT 库是一个专为 Arduino 平台设计的轻量级图形驱动库,核心目标是支持 Seeed Studio 推出的 2.8 英寸 TFT 触摸屏扩展板(v1.0 版本)。该硬件模块采用双芯片方案:显示控制器可选用 SPFD5408A 或 ST7781R 其中之一&…...

Python主流框架全解析

以下是 Python 常用框架的分类解析:一、Web 开发框架1. Django定位:全能型框架,内置 ORM、模板引擎、路由系统等特点:开箱即用(如自带后台管理、用户认证)遵循 MVC 设计模式(MTV 变体&#xff0…...

前端使用AI试水报告读

1 实用案例 1.1 表格样式生成 本示例用于生成包含富文本样式与单元格背景色的Word表格文档。 模板内容: 渲染代码: # python-docx-template/blob/master/tests/comments.py from docxtpl import DocxTemplate, RichText # data: python-docx-template/bl…...

STM32时钟系统解析与启动配置实践

1. STM32单片机启动时的时钟源选择机制刚接触STM32开发时,我总有个疑问:在main函数执行前,单片机是怎么跑起来的?特别是在我们还没配置系统时钟之前,CPU靠什么时钟在工作?这个问题困扰了我很久,…...

Laravel vs 主流PHP框架:终极对决

好的,我们来对比一下 Laravel 与其他一些主流 PHP 框架的特点和适用场景。这种对比通常涉及多个维度,包括易用性、性能、功能丰富度、社区支持等。以下是一个简要的对比表格,总结了 Laravel 与其他几个常见 PHP 框架(Symfony, Cod…...

一文搞懂 MySQL 主从复制

目录 一、什么是 MySQL 主从复制? 主从复制的核心作用(我们为什么要用它?) 二、主从复制的底层原理:大白话拆解全流程 先搞懂 2 个核心文件 再认识 3 个关键线程 完整同步流程,一步一步讲明白 步骤 …...

macos简单配置openclaw贝

1 实用案例 1.1 表格样式生成 本示例用于生成包含富文本样式与单元格背景色的Word表格文档。 模板内容: 渲染代码: # python-docx-template/blob/master/tests/comments.py from docxtpl import DocxTemplate, RichText # data: python-docx-template/bl…...

【MATLAB源码-第415期】基于MATLAB的等效电路与电热耦合的锂离子电池CC-CV充电控制、SOC估计及BMS保护与故障诊断仿真

操作环境:MATLAB 2024a1、算法描述基于等效电路与电热耦合的锂离子电池CC-CV充电控制及BMS保护仿真研究摘要锂离子电池作为电动汽车、储能系统与便携式电子设备中的核心储能单元,其充电过程不仅关系到能量补给效率,还直接影响安全性、寿命保持…...

营销自动化数据驱动 - 多源数据 OLAP 架构演进嘉

1. 流图:数据的河流 如果把传统的堆叠面积图想象成一块块整齐堆叠的积木,那么流图就像一条蜿蜒流淌的河流,河道的宽窄变化自然流畅,波峰波谷过渡平滑。 它特别适合展示多个类别数据随时间的变化趋势,尤其是当你想强调整…...

硬件笔记——使用OrCAD绘制原理图

一、新建工程新建工程,并输入工程的名称和路径,然后会弹出一个PAGE页面:二、修改PAGE页面大小有几种尺寸规格,也可以自定义尺寸,这里以尺寸B规格为例:三、添加原理图库到工程里点击工具栏右上角的芯片图标&…...

Burpsuite之暴力破解+验证码识别 | 添柴不加火萍

springboot自动配置 自动配置了大量组件,配置信息可以在application.properties文件中修改。 当添加了特定的Starter POM后,springboot会根据类路径上的jar包来自动配置bean(比如:springboot发现类路径上的MyBatis相关类&#xff…...

8250串行通信避坑指南:如何用内环测试快速定位硬件故障(附Proteus仿真文件)

8250串行通信避坑指南:如何用内环测试快速定位硬件故障 在嵌入式系统开发中,串行通信故障排查往往是最令人头疼的问题之一。当你面对一个无法正常通信的系统时,问题可能出在硬件连接、芯片配置、软件逻辑或者中断处理等任何一个环节。而8250这…...