C#中关于表达式的构建示例,备忘

中的计算表达式提供一种用于编写计算的便捷语法,可以通过使用控制流构造和绑定对这些计算进行排序和组合。 根据计算表达式的类型,可以将其视为表示 monad、monoids、monad 转换器和 applicative functor 的一种方式。 但是,与其他语言(例如 Haskell 中的 do-notation)不同,它们不依赖于单一抽象,也不依赖宏或其他形式的元编程来实现上下文相关的便捷语法。

一下是C# 中的一个简单示例,用于计算简单表达式:

csharp 复制代码
#region Demo
public interface ISampleExpression
{
    double? Calculate(Dictionary<string, double> parameters);
}

public class ConstantExpression : ISampleExpression
{
    double _value;

    public ConstantExpression(double value)
    {
        _value = value;
    }

    public double? Calculate(Dictionary<string, double> parameters)
    {
        return _value;
    }
}

public class VarExpression : ISampleExpression
{
    string _name;

    public VarExpression(string name)
    {
        _name = name;
    }

    public double? Calculate(Dictionary<string, double> parameters)
    {
        if (parameters == null
            || !parameters.Any()
            || !parameters.ContainsKey(_name))
        {
            return default;
        }
        return parameters[_name];
    }
}

public class OperateExpression : ISampleExpression
{
    ISampleExpression _leftExp;
    ISampleExpression _rightExp;
    char _operateSymbol;

    public OperateExpression(ISampleExpression leftExp, char operateSymbol, ISampleExpression rightExp)
    {
        _leftExp = leftExp;
        _operateSymbol = operateSymbol;
        _rightExp = rightExp;
    }

    public double? Calculate(Dictionary<string, double> parameters)
    {
        var leftVal = _leftExp.Calculate(parameters);
        var rightVal = _rightExp.Calculate(parameters);
        switch (_operateSymbol)
        {
            case '+':
                return leftVal + rightVal;
            case '-':
                return leftVal - rightVal;
            case '*':
                return leftVal * rightVal;
            case '/':
                if (rightVal == 0)
                {
                    return default;
                }
                return leftVal / rightVal;
            default:
                break;
        }
        return default;
    }
}

#endregion

上面用于计算表达式的类型

以下程序使用 Expression 类根据不同的 x 和 y 值计算表达式 x * (y + 2) 。

csharp 复制代码
static void Main(string[] args)
{


    ISampleExpression e = new OperateExpression(new VarExpression("x"),
                                                    '*',
                                                    new OperateExpression(
                                                    new VarExpression("y"),
                                                    '+',
                                                    new ConstantExpression(2)
                                                    )
                                                    );
    var vars = new Dictionary<string, double>();
    vars["x"] = 3;
    vars["y"] = 5;
    Console.WriteLine(e.Calculate(vars)); // "21"
    vars["x"] = 1.5;
    vars["y"] = 9;
    Console.WriteLine(e.Calculate(vars)); // "16.5"
}
相关推荐
先吃饱再说6 小时前
存储的进化:从 MySQL 到浏览器缓存,数据到底住在哪?
数据库
Nturmoils7 小时前
字段太多看不全,ksql 的展开模式和输出控制怎么用
数据库·后端
Databend9 小时前
Agent 轨迹分析与归因的数据工程实践
大数据·数据库·agent
这个DBA有点耶9 小时前
SQL改写进阶:标量子查询的“隐形代价”与消除实战
数据库·mysql·架构
smallyoung10 小时前
数据库乐观锁深度解析:MySQL、PostgreSQL 实战 + Spring Boot 集成指南
数据库·mysql·postgresql
parade岁月11 小时前
MySQL JOIN解析:朴实无华但食之有味
数据库·后端
用户31693538118311 小时前
MySQL服务无法启动问题解决全记录
数据库
vivo互联网技术14 小时前
从 10 分钟到 1 秒:ES 深度分页任意跳页的三轮优化实战
服务器·数据库·redis·elasticsearch·深度分页
倔强的石头_1 天前
《Kingbase护城河》——猎捕慢查询:执行计划的微观解析与索引调优实战
数据库
SelectDB1 天前
Apache Doris Python UDF:让 SQL 直接调用 Python 生态,支撑 Agent 时代复杂业务逻辑
大数据·数据库·python