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

MCP和Function Calling的区别

原文转载地址

之前一直浅浅看了一眼mcp,觉得和function calling并没有本质区别,被吹的太火了,这两天回头又看了一眼,又有了新的感悟。

让llm回答今天的天气

这种问题明显llm无法回答,因为llm无法感知外部世界,可是如果我们定义一个函数: getweather(day), 并向llm解释有这么一个函数,调用一下就可以知道今天的天气,只需要传入一个day参数就行。因此我们将参数,函数名,函数描述一并作为prompt传递给llm,llm就能知道调用这个函数的信息了。

真的能稳定调用成功吗?

我们知道llm的输出并不稳定,哪怕同一个输入都会产生不同答案。而写代码都知道,函数名,参数哪怕错一个字母,多一个括号,代码就报错,调用失败。

因此,llm一样会遇到这个问题: llm不一定会规规整整的调用函数的输出。llm可能会多一个括号,多一个分号,甚至说一些叽里咕噜客套话,里面藏着调用的代码,这对于我们从llm输出结果中找到调用函数的语句不利。

让llm学会稳定调用函数

为了稳定function calling,老老实实按照一定标准输出调用函数名字和参数,我们可以对llm针对性训练,该输出函数名的时候就输出函数名,后面必定跟着这个函数的参数以及值。

让llm调用更多的函数

不同的人写的函数难以统一,对函数的描述也不相同,人能理解,可是llm不一定会。

通过训练,llm可以学会了如何稳定调用A风格描述定义的function,但是万一有人换个B风格描述function来让llm调用,llm岂不是又抓瞎了,输出不稳定了。

mcp统一被调用的函数的描述规范

正是因为不同人描述函数风格习惯不一样,llm不会稳定调用函数,那么不如统一标准风格吧。

按照大家约定好的规则描述函数,比如先描述函数名,再描述参数名,不准反过来。而llm也按照这种风格的数据集进行训练,那么llm就能稳定调用这种风格描述的函数了。以后所有人都按照这种风格描述函数,就能让llm稳定调用任何新提供的函数,今天加一个获取股票的函数getstocks(xxx),明天加一个查询水电的函数getbills(xxx),都能稳定调用不报错了。

函数参数变化怎么办

我们知道,代码总是再不断地重构迭代的。比如还是查天气的函数getweather,函数提供一个参数day,现在重构升级了,函数变成getweather(day, location), 不仅仅可以查自己IP位置的天气,还能查看别的地方的天气,传入一个新的location参数就好了。

可llm哪知道函数接口变化了,只能费时费力去改prompt描述,所以mcp采用client和server模式,client会去向server询问当前这个外部函数的参数是什么,然后传回给llm,这样llm就知道最新的参数,再也不用担心接口变动而调用失败了。

总结

MCP提供了一种统一的外部接描述和调用规范,今后的llm都针对这种描述规范训练一下,llm就能稳定调用符合mcp规范的接口了,再也不用担心llm总是调用失败了。

mcp还将接口参数的描述从prompt端转移到server端,不再是写死接口参数,而是改成动态获取,以后接口随便怎么升级和改动,都能稳稳成功调用。

http://www.fuzeviewer.com/news/473/

相关文章:

  • 《程序员修炼之道》 阅读笔记三
  • 第四篇:docker底层原理
  • 关于springboot+Servlet报错404的问题
  • Codechef Painting Tree 题解 [ 蓝 ] [ 树形 DP ] [ 概率期望 ] [ 分类讨论 ]
  • 【CI130x 离在线】如何运行 curl 脚本
  • 这才是真正的AI NAS!极空间私有云Z2Ultra评测
  • 新东方第三节课名言作文
  • 十月阅读_3
  • 中考_体育
  • 常见问题处理 --- phpstudy启动mysql失败
  • 20232308 2025-2026-1 《网络与系统攻防技术》实验三实验报告
  • 【密码学实战】openHiTLS PKCS12命令行程序: PKCS12文件生成与解析
  • 「CTSC2017-游戏」题解
  • vue3 vue3-form-element表单生成工具 输入框增加后缀
  • 20232402 2025-2026-1 《网络与系统攻防技术》实验三实验报告
  • 掘金2025年:数字化商业浪潮下,如何选对平台与伙伴?一站式多商户商城系统推荐榜发布,多商户商城代理招募/多商户项目合伙人加盟/一站式开店代理项目加盟
  • 为医疗器械行业搭建“数字桥梁”,破解协同效率与合规难题
  • PostgreSQL 服务版
  • 20232307 2025-2026-1 《网络与系统攻防技术》实验三实验报告
  • 2025年10月办公家具公司评价榜:基于真实数据的权威推荐清单
  • vue+antv/x6项目使用问题
  • 《程序员修炼之道:从小工到专家》前五分之一观后感
  • 坐标系与投影关系
  • 用gdb的动态视角看ret2text的实现
  • 1027随笔
  • ask_skill
  • SVN 主分支合并之通过主分支合并子分支执行流程
  • 现代c++编程体验2
  • 化繁为简:解密国标GB28181算法算力平台EasyGBS如何以兼容性与易用性赋能安防集成
  • 计算机毕业设计springboot音乐畅听系统 基于Spring Boot框架的智能音乐播放系统编写 Spring Boot驱动的音乐在线欣赏平台构建