阿里云「飞天发布时刻」2024来啦!新产品、新特性、新能力、新方案,等你来探~ 了解详情
写点什么

框架设计规范的新方向

  • 2008-11-06
  • 本文字数:1361 字

    阅读完需:约 4 分钟

微软的框架设计规范是设计的准则,它期望所有的微软类库和独立开发者都能够遵循这一准则。随着每个.NET 框架版本的发布,以及在行业内的测试,它们的版本也得到了精化。通过 Cwalina 与 Abram 所著的《框架设计规范》第二版的发布,我们可以看到微软在今后几年的发展方向。

或许最令人惊讶的事实是日渐增长的对于测试驱动开发和依赖注入的重视。在可重用框架的场景下,通过测试驱动开发设计出的框架是真实可用的,而不是简单地推理。他们希望这样可以反过来杜绝某种趋势,那就是过度复杂地设计一些根本不会用到的功能。

谈到这一问题,就不得不指出的是微软当前正在推动的一个活动,即针对所有库的第 1 个版本进行最低限度设计。这不同于在第一次就要试图将所有事情做对,微软推荐在最开始只需要满足需求中绝对需要的特性。Abrams 和 Cwalina 建议在最初并不需要考虑扩展性,只有到需求变得非常清晰的时候,才在后一个版本中考虑。从某个方面来讲,这是微软旧有传统的回归,它只会在第三个版本中提供真正完成的应用程序。

在其它领域,微软则完全没有改变。他们仍然强调所谓的“基坑成功(Pit of Success)”,并将其作为设计圭臬,特别是在谈及开发者的生产力时,尤其如此。例如,对于 Exception 类的构造函数应该定义为 protected,而不是 public,这就可以强迫开发者采取正确的方式,抛出一个适当的异常。相反地,我们现在必须借助于 FxCop 准则对此进行检查。

他们不断鼓吹的另一个原则是“相同的力量”,对这一目标的追求可以使得新类库的工作方式,对于其他.NET 类库的用户而言是直观的。它被应用在代码的各个方面,包括命名规范、术语约定以及设计模式。

微软强调的新增内容是依赖注入。虽然他们总是被用在各个类库中,但从未如此正式地将其看作为一种设计模式。相反,它仅仅在 API 需要时作为一种补充。这种情况到了.NET 3.0 有所改变,依赖注入与控制反转都是一种特定的要求。

一旦涉及到 CLR 顶端的技术,框架设计规范就是不可知的。例如,微软并没有用它来推动依赖注入类库,即托管的可扩展性框架的运用。相反,其重点放在设计目标、编写松散耦合、可测试的代码上。

在 PDC 中,特别强调了某些特定的建议,包括:

类的构造函数应该是延迟的。从本质上讲,他们所要做的不仅仅是要捕获参数,因为通常不会用到新的被实例化的类。

属性应该:

  • 不要抛出异常(getter)
  • 不要被用作转换(getter)
  • 不要产生副作用(setter)
  • 足够快速,而不用考虑对象的状态
  • 永远不要返回一个数组,或者一个克隆的列表(getter)

扩展方法应该用于为接口“添加”重载,也可以用于管理类库之间的依赖。例如,如果程序集 B 依赖于程序集 A,则 A 中的类不会暴露 B 中的功能。然而,A 中的类可以通过 B 中的扩展方法进行标记,提供依赖的效果,但实际这种依赖并不存在。

对于类的层级,总体不应超过 2 到 3 个层级。过深的层级会导致很难保证每个实现,因为实现必须遵循整个契约。谈到这一问题,其中至关重要的一点,就是为了保证工作正确,任何重写的成员都应该具有一个显式的契约细节,以包含子类需要做的内容。

接口应该小,最好只包含一个方法。每增加一个额外的方法,就可能使得接口难以正确设计,而在将来甚至会需要更多的方法。如果不适用于抽象基类,可以将接口串联在一起,以构建其功能。

查看英文原文: New Directions in Framework Design Guidelines

2008-11-06 23:311000
用户头像

发布了 109 篇内容, 共 39.7 次阅读, 收获喜欢 13 次。

关注

评论

发布
暂无评论
发现更多内容

架构训练营第八周

xiaomao

第八周作业总结

hunk

极客大学架构师训练营

第七周作业

Geek_9527

架构设计:企业总体架构要如何做?小白也能快速领悟的设计思想

互联网应用架构

架构设计

生产环境全链路压测建设历程之八 生产全链路压测和传统压测的差异点

数列科技杨德华

第3周学习总结

Binary

极客大学架构师训练营

数据应用(一)

wing

极客大学架构师训练营

第八周作业

Geek_9527

架构师训练营第二期 第 8 周总结

月下独酌

极客大学架构师训练营

架构师训练营第 1 期 -- 第十二周作业

发酵的死神

极客大学架构师训练营

第 8 周 系统架构总结

心在那片海

第3周作业提交

Binary

极客大学架构师训练营

架构师训练营第 1 期 -- 第十二周学习总结

发酵的死神

极客大学架构师训练营

架构师训练营第 1 期 - week12 - 作业

lucian

极客大学架构师训练营

架构师训练营第十二周总结

吴传禹

极客大学架构师训练营

Architecture Phase1 Week12:Summarize

phylony-lu

极客大学架构师训练营

架构师第三周作业

胡益

单词匹配算法,算法常见的模数1000000007 模数10 ^ 9 + 7,swift mock URLSession,John 易筋 ARTS 打卡 Week 30

John(易筋)

ARTS 打卡计划 单词匹配算法 swift mock数据 算法中的模数

第 8 周 系统架构作业

心在那片海

第8周作业

hunk

极客大学架构师训练营

Architecture Phase1 Week12:HomeWork

phylony-lu

架构师训练营第十二周命题作业

一马行千里

大数据概述

garlic

极客大学架构师训练营

第十二周 作业2

Yangjing

极客大学架构师训练营

架构训练营第八周总结

xiaomao

第12周总结

睡觉表演者

极客时间架构师一期

数据应用 课后练习

ABS

Java内存模型

懒AI患者

常量池 Java内存模型 元数据区

Week 8 性能优化

evildracula

学习 架构

架构师训练营第2期 第8周命题作业

月下独酌

极客大学架构师训练营

架构师训练营第十二周作业

吴传禹

极客大学架构师训练营

框架设计规范的新方向_.NET_Jonathan Allen_InfoQ精选文章