您现在的位置:主页 > 技术中心 > 编程开发 > .net

.NET独有的精巧泛型设计模式(2)

来源:未知 责任编辑:责任编辑 发表时间:2014-05-10 12:25 点击:

/// <typeparam name="K">Type of the node value.</typeparam>
class TreeNode<T,K> where T:TreeNode<T,K> where K: IComparable<K>
{
    public T LeftChild { get; set; }

    public T RightChild { get; set; }

    public T Parent { get; set; }

    public K Value { get; set; }
}
 

之后,实现任何一种特殊二叉树结构,比如RBTreeNode代表红黑树节点,可以这样:

class RBTreeNode : TreeNode<RBTreeNode,Int32>
{
    /// <summary>
    /// 树节点颜色,是否为红。
    /// </summary>
    public bool IsRed { get; set; }

    public override string ToString()
    {
        return this.Value + "," + (this.IsRed ? "R" : "B");
    }
}
 

这个是AVL树:

class AvlTreeNode : TreeNode<AvlTreeNode,Int32>
{
    /// <summary>
    /// 节点的平衡度
    /// </summary>
    public int Balance { get; set; }

    public override string ToString()
    {
        return "Balance: " + Balance + ", Value: " + this.Value;
    }
}
 

不但完全符合OCP原则,而且再也不需要as来强制转换节点类型了。

这肯定不是我的首创,其实.NET Framework中已经不少这样的设计,比如IComparable<T>接口。也有不少优秀的框架采用了类似的设计,比如大石头同学的ORM框架NewLife.XCode。

看上去也很简单吧,但是很多人思维还停留在面向对象语言刚诞生的阶段,还不习惯用这种设计模式。我认为这种写法足够典型和通用,足以得上一种设计模式,而且是.NET特殊优势,独特魅力。

说到设计模式,其实GOF提出的23种设计模式多年了,已经过时,出现了许多新模式(比如并发编程方面,参考Wiki Design Pattern)。旧有的模式中,有的已经包含在.NET语言特性中,有的模式实现方式已经改头换面。尤其在泛型出现后,许多模式的实现可以变得简洁许多,优雅许多。

不要一遍遍炒过去的冷饭,设计模式应该与时俱进,永远是充满新鲜活力的话题。



摘自 XiaoMing的点滴
 

发表评论
请自觉遵守互联网相关的政策法规,严禁发布色情、暴力、反动的言论。
评价:
表情:
用户名: 验证码:点击我更换图片

推荐热点

  • 浅析.NET下XML数据访问新机制
  • asp.net 面试+笔试题目第1/2页
  • C# 邮件地址是否合法的验证
  • C#高级编程:数据库连接[1]
  • asp.net 设置GridView的选中行的实现代码
  • 经典C++程序1
  • IIS 自动回收导致后台定时器失效的问题解决
  • ASP.NET&#160;GridView列表代码示例
  • 微软ASP.NET站点部署指南(3):使用Web.Config文件
?? - ?? - ÝřŝžľŘÝź - TAGąęÇŠ - RSSśŠÔÄ - ??
Copyright © 2004-2024 上海卓卓网络科技有限公司