更加优雅的类型检查与传参---mcp源码分析

复制代码
def run(self, transport= "stdio", **kwargs):
    ...

我们如果要实现一个函数适配多个不同的入口,传统方法就是这样子做,定义一个入口函数,设置动态传入参数。

但这种方法简直是灾难,

1.不管选哪个 transport,都会一次性弹出 host、port、sse_path、json_response 等全部几十种参数,分不清哪个参数属于哪种传输方式,极易传错。

2.某个模式根本不需要其他参数,但类型检查器不会报错,运行时多余参数丢进 kwargs,底层函数不识别就会静默异常,调试极难。

如果想要更加优雅的类型检查与传参,python还提供了另外一种方式给我们使用,

复制代码
@overload
def run(self, transport: Literal["stdio"] = ...) -> None: ...

@overload
def run(
    self,
    transport: Literal["sse"],
    *,
    host: str = ...,
    port: int = ...,
    ...
) -> None: ...

def run(
    self,
    transport: Literal["stdio", "sse", "streamable-http"] = "stdio",
    **kwargs: Any,
) -> None:
    # 路由分发逻辑

重载 1:transport="stdio"

  • 只能传 transport="stdio"不允许额外关键字参数(host/port 等都不能传)
  • IDE 调用 server.run() 时不会弹出 host、port 等多余参数,类型检查器多传参数直接标红报错。

重载 2:transport="sse"

  • 必须显式指定 transport="sse"
  • *, 强制后续所有参数只能用关键字传参,不能位置传参;
  • 限定只能传入 SSE 专属配置:host、port、sse_path、证书配置等,其它无关参数静态报错。

def run(是唯一真实实现函数(运行时真正执行)

相关推荐
NE_STOP10 小时前
Vibe Coding -- 完整项目案例实操
java
荣码10 小时前
GraphRAG:普通RAG只能回答"点"的问题,我踩了4个坑才搞懂
java·python
SimonKing10 小时前
Google第三方授权登录
java·后端·程序员
明月光81810 小时前
从一行 @Builder 说起:重新拾起 Java 的 Lombok、注解与 Builder 模式
java
考虑考虑19 小时前
Mybatis实现批量插入
java·后端·mybatis
咖啡八杯20 小时前
GoF设计模式——中介者模式
java·后端·spring·设计模式
青石路1 天前
记一次多JDK版本问题的排查,一坑套一坑,差点没爬上来
java
像我这样帅的人丶你还1 天前
Java 后端详解(五):Redis 缓存
java·后端·全栈
plainGeekDev1 天前
GreenDAO → Room
android·java·kotlin
亦暖筑序1 天前
Java 8老系统AI Workflow实战:把一次性AI对话升级成可恢复工作流
java·后端