news 2026/4/23 11:13:22

大模型的MCP和function calling的使用方式有什么区别

作者头像

张小明

前端开发工程师

1.2k 24
文章封面图
大模型的MCP和function calling的使用方式有什么区别

MCP(Model Context Protocol)和Function Calling(函数调用)都是让“大模型能用外部能力”的机制,但设计目标、使用方式、抽象层级都有明显区别。下面从「是什么」「怎么用」「适合什么场景」三个层面给出一个工程向对比


一句话先区分

Function Calling
👉“模型按你给的函数签名,返回结构化参数,由你来执行函数”

MCP
👉“模型通过统一协议,自主发现、选择并调用外部工具/资源/服务”


一、Function Calling 是什么 & 怎么用

1️⃣ 核心思想

  • 模型不真正调用函数

  • 只做一件事:生成符合 schema 的 JSON

  • 宿主程序(你)负责:

    1. 解析 JSON
    2. 调用真实函数
    3. 把结果再喂回模型

2️⃣ 使用方式(典型流程)

用户输入 ↓ LLM(看到你注册的函数 schema) ↓ LLM 输出: { "name": "get_weather", "arguments": { "city": "北京" } } ↓ 你调用 get_weather("北京") ↓ 把结果再发给 LLM

3️⃣ 特点总结

✅ 优点

  • 简单、可控
  • 易调试
  • 非常适合单体应用 / API 网关

❌ 局限

  • 强耦合

    • 函数 schema 写死在 prompt / 请求里
  • 无发现能力

    • 模型只能用你“提前告诉它的函数”
  • 不适合跨进程、跨语言、跨服务


二、MCP 是什么 & 怎么用

1️⃣ MCP 的本质

MCP 是一个协议,不是一个模型能力

它定义了:

  • 模型 ↔ 工具 / 服务 之间
  • 如何发现、描述、调用能力

你可以理解为:

“给大模型用的 USB / HTTP + OpenAPI”


2️⃣ MCP 能暴露什么

一个 MCP Server 可以暴露三类能力:

类型举例
Tools发邮件、查数据库、跑代码
Resources文件、日志、数据库记录
Prompts复用 Prompt 模板

模型可以:

  • 动态发现
  • 自主选择
  • 多步调用

3️⃣ 使用方式(概念流程)

LLM 启动 ↓ 连接 MCP Server ↓ 发现可用 tools/resources ↓ 根据任务自主决定: - 调哪个 tool - 用什么参数 - 是否链式调用

模型并不是“被动等你塞函数定义”,而是:

像一个 agent,在一个工具生态里工作


三、关键差异对比(重点)

维度Function CallingMCP
抽象层级
是否协议✅(标准协议)
工具发现❌ 手写✅ 动态
执行位置宿主代码MCP Server
跨语言
多工具协作麻烦原生支持
Agent 场景一般非常适合

四、什么时候用哪个?

✅ 选 Function Calling,如果你:

  • 在做:

    • 后端 API
    • Chatbot
    • Web 应用
  • 工具数量少(<10)

  • 希望强控制、低复杂度

👉80% 产品都应该从 Function Calling 开始


✅ 选 MCP,如果你:

  • 在做:

    • AI Agent
    • IDE / Copilot
    • 内部工具平台
  • 工具来源复杂

  • 希望:

    • 插件化
    • 热插拔
    • 跨语言 / 跨团队

👉MCP 是“AI 工具生态”的基础设施


五、一个直观类比(非常重要)

类比对象Function CallingMCP
驱动方式写死函数即插即用
USB 之前每个设备单独驱动
USB 之后
HTTP vs RPCRPCHTTP + OpenAPI

六、是否“互相替代”?

不是替代关系

实际上:

MCP Server 内部,通常还是用 function calling 或普通代码实现的

可以理解为:

Function Calling = 单机函数调用能力 MCP = 分布式、标准化的函数/资源调用体系
版权声明: 本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若内容造成侵权/违法违规/事实不符,请联系邮箱:809451989@qq.com进行投诉反馈,一经查实,立即删除!
网站建设 2026/4/23 12:59:03

基于PLC的自动化物流分拣设计 (设计源文件+万字报告+讲解)(支持资料、图片参考_相关定制)_文章底部可以扫码

基于PLC的自动化物流分拣设计 (设计源文件万字报告讲解)&#xff08;支持资料、图片参考_相关定制&#xff09;_文章底部可以扫码 硬件是西门子S7-1200&#xff0c;用的博图软件。包含程序和仿真。 另外赠送一套参考程序和参考报告&#xff08;1w字&#xff09;参考文章&#x…

作者头像 李华
网站建设 2026/4/18 14:01:27

postgresql内的RLS规则

来源 https://chatgpt.com/share/6969eb21-0e50-8006-b6f3-6b9413d3be7a RLS安全,设置用户和某个特定人可以进行修改 using (user_id auth.uid() ) 上述代码中,除了user_id auth.uid(),我还想加入user_id1922d5ca-aa33-4abc-9759-6ccb05d6b533也可以查询数据,该怎么做? 注…

作者头像 李华
网站建设 2026/4/23 10:48:11

2026年Nature重磅研究:告别快速出成果的执念,让AI成为拓展科学边界的伙伴!

AI在学术科研中发挥的潜能,几乎已成为共识,如处理文献更快、写作效率更高、技术门槛更低...... 但矛盾也随之而来,那便是:个体科研效率在提升,真正具有颠覆性的科学突破,却在减少。 清华大学与芝加哥大学这两个研究团队,正是从这一矛盾出发,在Nature上发表了题为《Ar…

作者头像 李华
网站建设 2026/4/23 10:46:46

vc 运行库 |一键式解决VC++运行库及DLL缺失难题

在使用电脑系统时经常会出现丢失找不到某些文件的情况&#xff0c;由于很多常用软件都是采用 Microsoft Visual Studio 编写的&#xff0c;所以这类软件的运行需要依赖微软Visual C运行库&#xff0c;比如像 QQ、迅雷、Adobe 软件等等&#xff0c;如果没有安装VC运行库或者安装…

作者头像 李华