0

0

C# 如何实现Fluent API - 链式调用的优雅设计

星降

星降

发布时间:2026-01-24 08:27:51

|

569人浏览过

|

来源于php中文网

原创

c#中实现fluent api的核心是方法链式调用,通过返回this或新上下文对象(如builder、条件分支后的actionbuilder)提升可读性;常用场景包括计算链、对象构建、条件配置,并可通过接口泛型增强类型安全与调用顺序引导。

c# 如何实现fluent api - 链式调用的优雅设计

在 C# 中实现 Fluent API,核心是让每个方法调用后返回当前对象(或下一个上下文对象),从而支持链式调用。这种设计常见于构建器模式、查询构造、配置设置等场景,能显著提升代码的可读性和表达力。

1. 基本原理:返回 this

Fluent API 的基础是每个方法操作完后返回 this,允许连续调用其他方法。

public class Calculator
{
    private int _value;
<pre class='brush:php;toolbar:false;'>public Calculator(int start = 0) => _value = start;

public Calculator Add(int x)
{
    _value += x;
    return this; // 返回当前实例
}

public Calculator Multiply(int x)
{
    _value *= x;
    return this;
}

public int Result() => _value;

}

使用方式简洁流畅:

var result = new Calculator(5)
    .Add(3)
    .Multiply(2)
    .Result(); // 结果为 16

2. 使用 Builder 模式构建复杂对象

Fluent API 常用于对象构建,避免构造函数参数过多。

public class Person
{
    public string Name { get; set; }
    public int Age { get; set; }
    public string Email { get; set; }
<pre class='brush:php;toolbar:false;'>public override string ToString() => $"{Name}, {Age}岁, 邮箱: {Email}";

}

public class PersonBuilder { private readonly Person _person = new();

public PersonBuilder SetName(string name)
{
    _person.Name = name;
    return this;
}

public PersonBuilder SetAge(int age)
{
    _person.Age = age;
    return this;
}

public PersonBuilder SetEmail(string email)
{
    _person.Email = email;
    return this;
}

public Person Build() => _person;

}

调用示例:

A1.art
A1.art

一个创新的AI艺术应用平台,旨在简化和普及艺术创作

下载
var person = new PersonBuilder()
    .SetName("张三")
    .SetAge(28)
    .SetEmail("zhangsan@example.com")
    .Build();

3. 支持上下文切换的高级 Fluent 接口

某些场景需要在链中切换上下文,比如配置一个动作的条件和结果。

public class ConditionBuilder
{
    private bool _condition;
<pre class='brush:php;toolbar:false;'>public ConditionBuilder When(bool condition)
{
    _condition = condition;
    return this;
}

public ActionBuilder Then(Action action)
{
    if (_condition) action();
    return new ActionBuilder(); // 返回新上下文
}

}

public class ActionBuilder { public ActionBuilder AndThen(Action action) { action(); return this; }

public void Done() { /* 结束链 */ }

}

使用方式更具表达性:

new ConditionBuilder()
    .When(DateTime.Now.Hour > 12)
    .Then(() => Console.WriteLine("下午了"))
    .AndThen(() => Console.WriteLine("继续工作"))
    .Done();

4. 利用泛型和接口优化类型安全

通过接口约束方法可见性,防止用户在不该调用的地方调用某些方法。

public interface ICanAdd { Calculator Add(int x); }
public interface ICanMultiply { Calculator Multiply(int x); }
public interface ICanGetResult { int Result(); }
<p>public class Calculator : ICanAdd, ICanMultiply, ICanGetResult
{
private int _value;</p><pre class='brush:php;toolbar:false;'>public Calculator(int start = 0) => _value = start;

public Calculator Add(int x)
{
    _value += x;
    return this;
}

public Calculator Multiply(int x)
{
    _value *= x;
    return this;
}

public int Result() => _value;

}

虽然 C# 不强制限制链中顺序,但可通过接口组合引导正确使用方式。

基本上就这些。Fluent API 的关键在于“返回可继续操作的对象”,配合清晰命名和合理结构,能让调用代码像自然语言一样流畅。设计时注意职责分离、避免过度嵌套,才能真正实现优雅与实用并存。不复杂但容易忽略。

热门AI工具

更多
DeepSeek
DeepSeek

幻方量化公司旗下的开源大模型平台

豆包大模型
豆包大模型

字节跳动自主研发的一系列大型语言模型

通义千问
通义千问

阿里巴巴推出的全能AI助手

腾讯元宝
腾讯元宝

腾讯混元平台推出的AI助手

文心一言
文心一言

文心一言是百度开发的AI聊天机器人,通过对话可以生成各种形式的内容。

讯飞写作
讯飞写作

基于讯飞星火大模型的AI写作工具,可以快速生成新闻稿件、品宣文案、工作总结、心得体会等各种文文稿

即梦AI
即梦AI

一站式AI创作平台,免费AI图片和视频生成。

ChatGPT
ChatGPT

最最强大的AI聊天机器人程序,ChatGPT不单是聊天机器人,还能进行撰写邮件、视频脚本、文案、翻译、代码等任务。

相关专题

更多
硬盘接口类型介绍
硬盘接口类型介绍

硬盘接口类型有IDE、SATA、SCSI、Fibre Channel、USB、eSATA、mSATA、PCIe等等。详细介绍:1、IDE接口是一种并行接口,主要用于连接硬盘和光驱等设备,它主要有两种类型:ATA和ATAPI,IDE接口已经逐渐被SATA接口;2、SATA接口是一种串行接口,相较于IDE接口,它具有更高的传输速度、更低的功耗和更小的体积;3、SCSI接口等等。

1923

2023.10.19

PHP接口编写教程
PHP接口编写教程

本专题整合了PHP接口编写教程,阅读专题下面的文章了解更多详细内容。

656

2025.10.17

php8.4实现接口限流的教程
php8.4实现接口限流的教程

PHP8.4本身不内置限流功能,需借助Redis(令牌桶)或Swoole(漏桶)实现;文件锁因I/O瓶颈、无跨机共享、秒级精度等缺陷不适用高并发场景。本专题为大家提供相关的文章、下载、课程内容,供大家免费下载体验。

2392

2025.12.29

java接口相关教程
java接口相关教程

本专题整合了java接口相关内容,阅读专题下面的文章了解更多详细内容。

47

2026.01.19

class在c语言中的意思
class在c语言中的意思

在C语言中,"class" 是一个关键字,用于定义一个类。想了解更多class的相关内容,可以阅读本专题下面的文章。

870

2024.01.03

python中class的含义
python中class的含义

本专题整合了python中class的相关内容,阅读专题下面的文章了解更多详细内容。

30

2025.12.06

Go高并发任务调度与Goroutine池化实践
Go高并发任务调度与Goroutine池化实践

本专题围绕 Go 语言在高并发任务处理场景中的实践展开,系统讲解 Goroutine 调度模型、Channel 通信机制以及并发控制策略。内容包括任务队列设计、Goroutine 池化管理、资源限制控制以及并发任务的性能优化方法。通过实际案例演示,帮助开发者构建稳定高效的 Go 并发任务处理系统,提高系统在高负载环境下的处理能力与稳定性。

22

2026.03.10

Kotlin Android模块化架构与组件化开发实践
Kotlin Android模块化架构与组件化开发实践

本专题围绕 Kotlin 在 Android 应用开发中的架构实践展开,重点讲解模块化设计与组件化开发的实现思路。内容包括项目模块拆分策略、公共组件封装、依赖管理优化、路由通信机制以及大型项目的工程化管理方法。通过真实项目案例分析,帮助开发者构建结构清晰、易扩展且维护成本低的 Android 应用架构体系,提升团队协作效率与项目迭代速度。

48

2026.03.09

JavaScript浏览器渲染机制与前端性能优化实践
JavaScript浏览器渲染机制与前端性能优化实践

本专题围绕 JavaScript 在浏览器中的执行与渲染机制展开,系统讲解 DOM 构建、CSSOM 解析、重排与重绘原理,以及关键渲染路径优化方法。内容涵盖事件循环机制、异步任务调度、资源加载优化、代码拆分与懒加载等性能优化策略。通过真实前端项目案例,帮助开发者理解浏览器底层工作原理,并掌握提升网页加载速度与交互体验的实用技巧。

93

2026.03.06

热门下载

更多
网站特效
/
网站源码
/
网站素材
/
前端模板

精品课程

更多
相关推荐
/
热门推荐
/
最新课程
C# 教程
C# 教程

共94课时 | 11.1万人学习

C 教程
C 教程

共75课时 | 5.4万人学习

C++教程
C++教程

共115课时 | 21.5万人学习

关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送

Copyright 2014-2026 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号