你有没有想过,为什么 AI 能回答“今天上海天气怎么样?”这种实时问题,甚至帮你预订机票?明明它的训练数据截止到去年,怎么会对现在的事情了如指掌?

答案就藏在一个核心技术里——工具调用(Tool Calling)

简单说,工具调用就是让大模型在遇到自己搞不定的问题时,能像我们一样,打开一个“工具箱”,借用外部工具来完成任务。

这个“工具箱”里什么都有:网页搜索、计算器、API 调用、数据库查询……任何能帮它完成特定任务的,都可以是它的工具。

目前,工具调用技术已经相当成熟,几乎所有主流的 AI 大模型和开发平台都已支持。

AI 真的会“自己”调用工具吗?

一听到“工具调用”,很多人会误以为是 AI 服务器自己去执行了某个工具。

大错特错!

真相是:AI 只负责“提要求”,而真正干活的,是我们自己的应用程序。

整个过程更像是一个分工明确的团队协作。我们以“什么是 MCP?”这个问题为例,看看团队是如何配合的:

  1. 用户:提出问题:“什么是 MCP?”
  2. 程序(项目经理):将问题转达给 大模型(技术专家)
  3. 大模型(技术专家):分析后发现知识库里没有,判断需要上网搜索,于是向程序提要求:“我需要用「网页抓取工具」查一下,关键词是 MCP”。
  4. 程序(项目经理):收到请求,立刻安排 网页抓取工具(实习生) 去执行。
  5. 网页抓取工具(实习生):勤勤恳恳地完成抓取,把数据返回给程序。
  6. 程序(项目经理):将抓取到的信息整理好,再次交给 大模型(技术专家)
  7. 大模型(技术专家):阅读信息,总结提炼,生成一份通俗易懂的回答。
  8. 程序(项目经理):最后,将这份完美的答案呈现给用户。
sequenceDiagram
participant 用户
participant 应用程序 (项目经理)
participant 大模型 (技术专家)
participant 网页抓取工具 (实习生)

用户->>应用程序 (项目经理): 1. 提问: "什么是MCP?"
应用程序 (项目经理)->>大模型 (技术专家): 2. 传递用户问题
大模型 (技术专家)->>大模型 (技术专家): 3. 分析问题,发现知识盲区
大模型 (技术专家)->>应用程序 (项目经理): 4. 请求调用工具<br/>工具: 网页抓取工具<br/>参数: 搜索 "MCP"
应用程序 (项目经理)->>网页抓取工具 (实习生): 5. 执行网页抓取
网页抓取工具 (实习生)->>应用程序 (项目经理): 6. 返回抓取结果
应用程序 (项目经理)->>大模型 (技术专家): 7. 将结果传回
大模型 (技术专家)->>大模型 (技术专家): 8. 分析信息,生成回答
大模型 (技术专家)->>应用程序 (项目经理): 9. 返回最终答案
应用程序 (项目经理)->>用户: 10. 呈现答案

Note over 用户,网页抓取工具: 核心:AI 不直接执行工具,由应用程序协调
Note over 大模型 (技术专家): AI 只负责思考和决策
Note over 网页抓取工具 (实习生): 工具在安全可控的环境中执行

看明白了吗?AI 只是“大脑”,负责思考和决策,而我们的应用程序才是“手脚”,负责执行和落地。

为什么要设计得这么“麻烦”?

你可能会问:为什么不让 AI 直接调用工具,一步到位?这样来回传递不浪费时间吗?

这背后最重要的考量是——安全!

这种设计确保了 AI 永远无法直接触碰你系统的核心资源。所有操作都必须经过你程序的“批准”,你拥有绝对的控制权,可以决定 AI 能做什么,不能做什么。

举个极端点的例子:假如你开发了一个“房屋爆破”工具。

  • 现在的方式:用户对 AI 说“帮我把这栋楼炸了”。AI 分析后,会向你的程序申请:“我需要使用「房屋爆破」工具”。这时,你的程序可以立刻拒绝这个危险请求,从而避免灾难。
  • 如果 AI 直接调用:AI 觉得这个需求很合理,直接就执行了。等你反应过来,房子可能已经没了。

把决定权留在我们自己手里,既能利用 AI 的智慧,又能保证系统的安全,还能减轻 AI 服务器的负担,何乐而不为呢?

工具调用 vs 功能调用

如果你在看技术文档时遇到 Function Calling(功能调用) 这个词,别懵,它和 Tool Calling(工具调用) 说的完全是同一件事!只是不同厂商或开发者习惯的叫法不同。

Spring AI 的官方文档开篇就明确了这一点:

我个人更喜欢“工具调用”这个说法,因为它更形象。“Function”一听就像是程序员的黑话,而“工具”则更加通俗易懂,不是吗?


好了,今天关于“工具调用”的分享就到这里。

希望这篇文章能帮你彻底搞懂 AI 是如何借助外部力量变聪明的。如果你觉得有收获,不妨点个赞在看,或者分享给更多朋友。

对于工具调用,你还有什么疑问或有趣的想法?欢迎在评论区留言讨论!

AI 为何能查天气、订机票?揭秘大模型背后的“神秘工具箱”的更多相关文章

  1. 华为高级研究员谢凌曦:下一代AI将走向何方?盘古大模型探路之旅

    摘要:为了更深入理解千亿参数的盘古大模型,华为云社区采访到了华为云EI盘古团队高级研究员谢凌曦.谢博士以非常通俗的方式为我们娓娓道来了盘古大模型研发的"前世今生",以及它背后的艰难 ...

  2. AI大模型学习了解

    # 百度文心 上线时间:2019年3月 官方介绍:https://wenxin.baidu.com/ 发布地点: 参考资料: 2600亿!全球最大中文单体模型鹏城-百度·文心发布 # 华为盘古 上线时 ...

  3. 小故事学设计模式之Observer : (三) 老婆帮忙订机票

    (IT的事就是过场多,过场多了就容易忘,所以我们不妨看一个记一个,这也是一个办法,顺便还能跟同行们交流一下)  要和老婆一起回老家了, 成都离我们安徽太远, 两个人飞一下过去就要花掉近三千块, 于是我 ...

  4. 员工离职困扰?来看AI如何解决,基于人力资源分析的 ML 模型构建全方案 ⛵

    作者:韩信子@ShowMeAI 数据分析实战系列:https://www.showmeai.tech/tutorials/40 机器学习实战系列:https://www.showmeai.tech/t ...

  5. POJ 2985 The k-th Largest Group(树状数组 并查集/查找第k大的数)

    传送门 The k-th Largest Group Time Limit: 2000MS   Memory Limit: 131072K Total Submissions: 8690   Acce ...

  6. HDU 3726 Graph and Queries 平衡树+前向星+并查集+离线操作+逆向思维 数据结构大综合题

    Graph and Queries Time Limit: 10000/5000 MS (Java/Others)    Memory Limit: 32768/32768 K (Java/Other ...

  7. 51Nod - 1640 天气晴朗的魔法 大+小生成树(最大值最小)/二分

    天气晴朗的魔法 这样阴沉的天气持续下去,我们不免担心起他的健康.   51nod魔法学校近日开展了主题为“天气晴朗”的魔法交流活动.   N名魔法师按阵法站好,之后选取N - 1条魔法链将所有魔法师的 ...

  8. 阿里AI芯片:12nm工艺、709平方毫米大核心

    含光出自<列子·汤问>篇有“上古三剑”一章,寓意含而不露,光而不耀,象征含光 800 无形却强劲的算力. 含光 800 是一款 AI 芯片,偏重推理.据介绍,1 颗含光 800 的算力相当 ...

  9. 揭秘String类型背后的故事——带你领略汇编语言魅力

    字符串或串(String)是由数字.字母.下划线组成的一串字符.一般记为 s=“a1a2···an”(n>=0).它是编程语言中表示文本的数据类型.在程序设计中,字符串(string)为符号或数 ...

  10. 这可能是AI、机器学习和大数据领域覆盖最全的一份速查表

    https://mp.weixin.qq.com/s?__biz=MjM5ODE1NDYyMA==&mid=2653390110&idx=1&sn=b3e5d6e946b719 ...

随机推荐

  1. 腾讯Java后端一面,被速通了!

    分享一篇腾讯的后端Java一面凉经,被速通了, 大家感受一下难度如何. 这次面试的考察覆盖了从 项目经验的深度挖掘(面试官非常看重 STAR 法则的应用)到 扎实的计算机基础(经典的 TCP/UDP ...

  2. jetbrains这是作啥妖呢,用了好久都没有问题,现在这是咋了?

    rider今天更新了下2025.1 数据库驱动下载不来: 插件不能正常访问: 清理下用户的配置目录: %UserProfile%\AppData\Local\JetBrains %UserProfil ...

  3. 基于Kubernetes可扩展的Selenium 并行自动化测试部署及搭建(2)——Win10环境下Kubernetes(k8s)部署

    继续上一篇,本篇进行K8S环境部署. K8s部署: 1.  访问k8s-for-docker-desktop 的github地址: https://github.com/AliyunContainer ...

  4. 鸿蒙Next开发实战教程:实现抖音长按快速评论特效

    开篇点题,今天玩点花的. 不知道大家有没有发现,抖音上的评论键长按会弹出一排表情框用于快速评论,不过现在鸿蒙原生版的抖音还没有这个功能,今天幽蓝君就小试牛刀,在鸿蒙上做一下这个功能,也是应一位友友的私 ...

  5. 关于#pragma comment的小认识

    #pragma 指令 #pragma为预处理指令,作用是设定编译器的状态或者是指示编译器完成一些特定的动作.#pragma指令对每个编译器给出了一个方法,在保持与C和C++语言完全兼容的情况下,给出主 ...

  6. 远程服务器(腾讯云轻量服务器)上安装SQL Server以及SQL Server Management Studio,以及EFCore对其的连接

    SQL Server的安装 下载地址:https://www.microsoft.com/zh-cn/sql-server/sql-server-downloads 安装教程参考:https://bl ...

  7. Time Series in pandas

    Time Series import pandas as pd import numpy as np Date and Time data types and tools from datetime ...

  8. 再论“ArcGIS AddIN之工具不可用”

    工作需要,开发arcgis的addin插件.从网上找了工程范例,编译dll,没有生成esriAddIn文件. 第二次,重新创建addin类型的动态库工程,从范例中复制类文件到工程中,编译dll,正常生 ...

  9. 【AI+教学】让课堂实时讲解语音知识库沉淀下来

    今天给大家分享一个教学的 AI 使用场景,主要用来解决课堂老师实时讲解的内容如何让学生快速了解学习. 一.教学场景说明: 课堂上老师上完课后,课堂实时讲解的内容,部分与教材或者课件有偏差(临场发挥), ...

  10. 自定义Marix的自定义动画,支持缓动动画属性

    最近用画布的MatrixTransForm做变换,需要用Matrix做动画处理,网上冲浪找了一圈,没有找出好的解决方法 Stack Overflow 给出了一部分的解决方法,但是不支持缓动函数,貌似不 ...