news 2026/4/27 9:43:32

Function Call 和 MCP 的区别(举例子,一文说明白)

作者头像

张小明

前端开发工程师

1.2k 24
文章封面图
Function Call 和 MCP 的区别(举例子,一文说明白)

一、前言

过去一年里,Function Call 成为最常用的“让 AI 调用代码”的方式。
但是当你的业务变复杂,比如:

  • 访问数据库
  • 操作本地文件系统
  • 管理多个工具
  • 调用公司内部 API
  • 多个模型复用同一套工具

Function Call 就开始吃力了。

于是,MCP出现了,它解决了 Function Call 的所有局限,成为下一代 AI 工具调用标准。

本文将通过Node.js 实例,让你直观理解两者区别。

二、概念总结:一句话说清两者区别

Function Call
模型提示你:“我要调用这个函数”,然后你负责执行。

MCP
模型自动发现和调用已注册的“工具”,开发者只负责定义工具,不负责执行。

一句话:

Function Call:模型说“我需要工具”,你来执行。 MCP:模型自己执行工具,你只负责提供工具。

三、用例对比:查询某个城市的天气

我们以“查询北京天气”为例进行对比。

目标:
让用户问:“北京天气怎么样?”
模型自动获取天气数据,并返回结果。

3.1 Function Call 示例(Node.js)

代码结构
function_call/ ├── app.js └── weather.js
步骤1:你需要手写工具函数(核心)
import axios from "axios"; export async function getWeather(city) { const apiKey = "your_api_key_here"; const url = `https://api.open-meteo.com/v1/forecast?latitude=39.9&longitude=116.4&hourly=temperature_2m`; const resp = await axios.get(url); return `当前温度:${resp.data.hourly.temperature_2m[0]}°C`; }
步骤2:把工具绑定给模型(你要写)
import { ChatOpenAI } from "@langchain/openai"; import { getWeather } from "./weather.js"; const tools = [ { type: "function", function: { name: "get_weather", description: "获取指定城市的天气信息", parameters: { type: "object", properties: { city: { type: "string" } }, required: ["city"] } } } ]; const llm = new ChatOpenAI({ model: "gpt-4o-mini" }).bind({ tools }); async function run() { const res = await llm.invoke("北京天气怎么样"); if (res.tool_calls?.length > 0) { const { city } = res.tool_calls[0].args; // 你负责执行工具 const weather = await getWeather(city); console.log("返回天气:", weather); } } run();
Function Call 的特点

你必须:

  • ❗手写 getWeather
  • ❗手动执行工具
  • ❗手动把结果反馈给模型
  • ❗每个模型都需要绑一遍 tools

当你的工具越来越多时,维护成本越来越高。

3.2 MCP 示例(Node.js)

在 MCP 中,你只需要定义工具,模型会:

✔ 自动发现工具
✔ 自动决定什么时候调用
✔ MCPClient 自动执行
✔ 你不需要任何其它代码

步骤1:定义一个 MCP 天气服务

新建:mcp-weather-server.js

import { Server } from "@modelcontextprotocol/sdk/server"; import axios from "axios"; const server = new Server({ name: "weather-service", version: "1.0", }); // 注册自定义工具 server.tool( "get_weather", "获取天气", { type: "object", properties: { city: { type: "string" } }, required: ["city"] }, async ({ city }) => { // 你可以接数据库/公司内网 API 都行 const url = `https://api.open-meteo.com/v1/forecast?latitude=39.9&longitude=116.4&hourly=temperature_2m`; const resp = await axios.get(url); const temp = resp.data.hourly.temperature_2m[0]; return { weather: `${city}当前温度:${temp}°C` }; } ); server.start();
步骤2:模型自动调用 MCP 工具
import { ChatOpenAI } from "@langchain/openai"; import { MCPClient } from "@langchain/langgraph/mcp"; import { ChatPromptTemplate } from "@langchain/core/prompts"; // 连接 MCP server const mcp = new MCPClient("stdio", { command: "node", args: ["./mcp-weather-server.js"] }); // 绑定到模型(让模型自动调用 MCP 工具) const llm = new ChatOpenAI({ model: "gpt-4o-mini", }).bind({ mcp }); const prompt = ChatPromptTemplate.fromMessages([ ["system", "你可以使用 MCP 工具获取天气信息。"], ["human", "{q}"] ]); async function ask(q) { const res = await prompt.pipe(llm).invoke({ q }); console.log("模型回答:\n", res.content); } ask("北京天气怎么样");

运行后输出类似:

模型回答: 北京当前温度:1°C
MCP 的特点
  • 模型自动识别并调取 get_weather
  • MCPClient 负责执行工具并返回结果
  • 开发者不用写其它code(如 res.tool_calls)
  • 所有 MCP 支持的模型都能直接复用这个工具

四、核心区别(通过例子直接看出来)

能力Function CallMCP
工具在哪里定义?代码里MCP Server 里
工具由谁调用?开发者手动调用模型自动调用
工具能否自动发现?❌ 不行✔️ 自动发现
是否支持文件系统 / DB / 本地脚本?你得自己写MCP 工具库直接支持
能否被多个模型共享?❌ 每个模型都要重新写✔️ MCP 工具可复用
安全性和权限?手动处理MCP 内置权限管理

一句话:

Function Call = 模型请求你,你再帮它调工具 MCP = 模型自己调工具,你只提供工具

学习资源推荐

如果你想更深入地学习大模型,以下是一些非常有价值的学习资源,这些资源将帮助你从不同角度学习大模型,提升你的实践能力。

一、全套AGI大模型学习路线

AI大模型时代的学习之旅:从基础到前沿,掌握人工智能的核心技能!​

因篇幅有限,仅展示部分资料,需要点击文章最下方名片即可前往获取

二、640套AI大模型报告合集

这套包含640份报告的合集,涵盖了AI大模型的理论研究、技术实现、行业应用等多个方面。无论您是科研人员、工程师,还是对AI大模型感兴趣的爱好者,这套报告合集都将为您提供宝贵的信息和启示

​因篇幅有限,仅展示部分资料,需要点击文章最下方名片即可前往获取

三、AI大模型经典PDF籍

随着人工智能技术的飞速发展,AI大模型已经成为了当今科技领域的一大热点。这些大型预训练模型,如GPT-3、BERT、XLNet等,以其强大的语言理解和生成能力,正在改变我们对人工智能的认识。 那以下这些PDF籍就是非常不错的学习资源。

因篇幅有限,仅展示部分资料,需要点击文章最下方名片即可前往获取

四、AI大模型商业化落地方案

作为普通人,入局大模型时代需要持续学习和实践,不断提高自己的技能和认知水平,同时也需要有责任感和伦理意识,为人工智能的健康发展贡献力量。

版权声明: 本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若内容造成侵权/违法违规/事实不符,请联系邮箱:809451989@qq.com进行投诉反馈,一经查实,立即删除!
网站建设 2026/4/16 19:37:31

教工平台采购避坑指南:别只看价格,服务价值更重要

✅作者简介:合肥自友科技 📌核心产品:智慧校园平台(包括教工管理、学工管理、教务管理、考务管理、后勤管理、德育管理、资产管理、公寓管理、实习管理、就业管理、离校管理、科研平台、档案管理、学生平台等26个子平台) 。公司所有人员均有多…

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

基于深度学习YOLOv12的安检x光危险物识别检测系统(YOLOv12+YOLO数据集+UI界面+登录注册界面+Python项目源码+模型)

一、项目介绍 针对安检X光图像中危险物品的自动检测需求,本研究提出了一种基于YOLOv12深度学习算法的危险物识别检测系统。该系统能够高效识别18类常见危险物品,包括刀具(如Knife、Throwing Knife)、工具(如Hammer、Sc…

作者头像 李华
网站建设 2026/4/27 1:51:58

RexUniNLU开源大模型部署教程:适配A10/A100/V100的CUDA 11.8环境配置

RexUniNLU开源大模型部署教程:适配A10/A100/V100的CUDA 11.8环境配置 1. 为什么你需要这个部署教程 你是不是也遇到过这样的问题:想快速跑通一个中文NLP大模型,结果卡在环境配置上——显卡驱动版本对不上、CUDA和PyTorch版本不兼容、模型加…

作者头像 李华
网站建设 2026/4/21 18:13:17

收藏备用!大模型学习路线完整版(小白/程序员入门必看)

如今,大模型技术已然成为驱动人工智能产业飞速发展的核心引擎,更是程序员提升核心竞争力、小白入门AI领域的关键突破口。无论你是刚接触AI的编程小白,还是有一定开发经验、想转型大模型方向的开发者,想要系统掌握大模型应用技能&a…

作者头像 李华
网站建设 2026/4/24 6:33:08

通过多智能体系统实现的时间序列可视化推理

时序分析支撑着众多实际应用,然而现有针对时序的特定方法及基于预训练大模型的方法在融合直观视觉推理、跨任务泛化与自适应工具调用方面仍存在局限。为应对这些挑战,我们提出MAS4TS——一个面向通用时序任务的工具驱动型多智能体系统。该系统构建于分析…

作者头像 李华