从零写一个智能体:最核心的“化身” —— 循环(Agent Loop)

这是《手把手写一个AI智能体》系列的第一篇。

别怕,我们不聊高深理论,只看一段不到100行的 Python 代码,就能让你搞懂"智能体"到底在做什么。


🎯 一句话总结:智能体 = 机器人 + 脑子 + 循环

想象一下,你让一个AI助手 帮你写代码、查文件、运行命令。

它不会一次就搞定所有事,而是"想一步 → 做一步 → 再想下一步"......直到完成。

这个"想→做→想 "的循环,就是所有智能体的灵魂

在代码里,它长这样:

python 复制代码
while stop_reason == "tool_use":
    response = LLM(messages, tools)   # 🤔 思考
    execute tools                      # 🛠️ 行动
    append results                     # 📝 反馈

我们把这个模式叫作 Agent Loop (智能体循环)。

今天,我们就用一段真实的代码,把这个循环拆开、揉碎,讲给你听。


🧱 总结构:代码长什么样?

我们先看一眼整体结构(完整代码在文末),它只有三个核心部分:

  1. 工具定义TOOLS)------ 告诉AI它能做什么,比如运行 bash 命令。

  2. 工具执行函数run_bash)------ 真正去执行命令,并返回结果。

  3. 核心循环agent_loop)------ 不断调用LLM,根据结果决定下一步。

整体流程就像打电话

  • 用户说一句话 → AI 思考 → 如果AI觉得需要"动一下",就调用工具 → 把结果告诉AI → AI继续思考 → 直到AI说"好了,我回答你"。

🔁 核心循环:while 里的秘密

让我们逐行看 agent_loop 函数:

python 复制代码
def agent_loop(messages: list):
    while True:
        response = client.chat.completions.create(...)   # 1. 问AI
        assistant_message = response.choices[0].message
        messages.append(assistant_message)               # 2. 记录AI的回答

        if not assistant_message.tool_calls:             # 3. 检查是否需要工具
            return                                       # 不需要 → 结束循环

        for tool_call in assistant_message.tool_calls:   # 4. 执行每个工具
            output = run_bash(command)                   # 🛠️ 执行
            messages.append({"role": "tool", ...})       # 5. 把结果放回对话

每轮循环做了三件事:

  • :把当前所有对话历史(包括之前的工具结果)发给LLM。

  • :如果LLM返回了 tool_calls,说明它想干点活;如果没有,说明它已经给出最终答案。

  • :执行每一个工具调用,把结果放回对话,然后继续循环

这就是"由工具结果驱动模型继续推理 "的核心机制。

如果没有这个循环,AI就只能回答一次,无法"边做边想"。


🛠️ 工具:bash 命令的"挡板"

代码中定义了一个 bash 工具,LLM 可以随时调用它。

但注意,执行之前有一个安全检查

python 复制代码
dangerous = ["rm -rf /", "sudo", "shutdown", "reboot", "> /dev/"]
if any(d in command for d in dangerous):
    return "Error: Dangerous command blocked"

为什么要这样做?

因为LLM有时候会"发疯",万一它想删掉你的整个系统......

所以我们加了

python 复制代码
text
s01 >> 帮我看看当前目录下有哪些文件

一个简单但有效的防火墙

另外,它还限制了输出长度(50000字符)和超时(120秒),防止AI卡死。


🧪 跑起来:一个真实的交互例子

假设你运行这个脚本,输入:

python 复制代码
text
s01 >> 帮我看看当前目录下有哪些文件
复制代码
看看当前目录下有哪些文件

发生了什么(大概流程):

  1. 用户问题 → 加入对话历史。

  2. 调用LLM → LLM 发现需要执行 ls -la,于是返回一个 tool_call

  3. 执行工具 → 运行 ls -la,输出文件列表。

  4. 把输出放回对话 → 变成一条 role="tool" 的消息。

  5. 再次调用LLM → LLM 看到工具结果,回答:"当前目录下有这些文件:......"

  6. 没有新的工具调用 → 循环结束,输出最终答案。

整个过程就像是AI一边动脑,一边动手,而且每次动手的结果都会被"喂"回给它,让它知道下一步该做什么。


🧩 为什么这是"最基础的设计"?

很多高级智能体框架(比如 LangChain、AutoGPT)都在这个模式上加了更复杂的东西:

  • 多工具注册

  • 记忆管理

  • 递归子任务

  • 用户确认

最底层的骨架 永远是这个 while 循环。

学会它,你就学会了所有智能体的原子操作

用一句话来记住:
工具调用是AI的"手",循环是AI的"呼吸"。

相关推荐
云安全助手11 小时前
Anthropic年度报告解读:AI重塑网络攻击形态,传统防御体系亟待升级
人工智能·安全·网络安全·ai大模型
谁似人间西林客11 小时前
汽车智能制造解决方案:如何通过智能仓储物流降本提效?
人工智能·汽车·制造
jiushiapwojdap11 小时前
Antigravity Awesome Skills:1527+ AI 编程助手的可安装技能库
人工智能·其他
顾北顾11 小时前
多头注意力机制
人工智能·深度学习·算法
hujinyuan2016011 小时前
2025年12月中国电子学会青少年机器人技术等级考试试卷(二级) 真题+答案
人工智能·算法·机器人
码农小白AI12 小时前
采购合同与来料证书对标校验,IACheck联动AI报告审核通审Agent版自动识别指标不符单据
人工智能
元岳数字人小元12 小时前
AI 数字人开发公司浅谈 虚拟数字人打造景区新服务
人工智能·人机交互·交互
哦哦~92112 小时前
AI赋能生物医学:从临床数据到药物分子性质预测实战培
人工智能·生物医学·药物分子
GIS数据转换器12 小时前
城市排水生命线安全运行监测平台深度解析
java·运维·人工智能·python·安全·数据挖掘·无人机
虫无涯12 小时前
本地离线大模型实战:Ollama + Llama 3.1 8B 全流程部署(适配VSCode Continue代码助手)
人工智能