• 胡言乱语一篇: 所谓面向对象与关系模型的矛盾


    神秀身是菩提树,心为明镜台; 时时勤拂拭,勿使惹尘埃。

    听起来很美,不是? 到今天大家还纯洁的相信Rows->Entities就是解决之道,代表了基于数据库的软件如何表现面向对象的精髓; 顽固而勤奋的寻找一个又一个的方案, 希望自己的设计水平能够一次又一次的进化,最终能够正确处理好两者之间的关系。不得不说一句,这种生硬的处理方式,要是能没矛盾,倒稀奇了。

    DTO能够让IDE提供足够的信息, 能够让编译器做出适当的检查,可即使是Rich Object,在ORM负责的这一段,能发挥的真实作用也不过仅此而已. 到底有啥必要去ORM? 业务逻辑本身什么时候要求所有的数据都要变成对象了? 我们想清楚没有, 到底需要的是什么能力, 想要解决什么问题? 在进行手工的或者自动化的ORM的时候,我们到底是在寻求帮助,还是在添加障碍?

    这么多年来,谁说这种方式不对,谁就被当菜鸟; 最后受益的真不知道是所谓的高手们呢,还是各种厂商。 C#这些语言中纯粹面向对象的部分, 不得不说,正在误入歧途。 制造一个麻烦,解决它,然后再制造一个。 也许这样,所有的厂商和程序员都有饭吃, 很好很强大。

    即便是伟大的无与伦比的面向对象,要想不受束缚的去设计,就必须隔断数据库和业务逻辑的关系; 这不能是添加一个数据操作层或者ORM去隔断,当咱们这么做的时候,实际上恰恰是在建立一种强联系。 最可笑的是,哪怕最清晰明了的模型,也会变得复杂起来。看看CommunityServer这么一个Web系统几年来的所谓进化吧,里面的一个又一个的死对象不断的浮肿起来,带来了多少不必要的繁文缛节和沉重负担。

    一个PetShop,作为一种展示无可厚非,可它又让多少人不得不在所谓的n层之间的接口上徒增烦恼呢?在我看来,什么狗屁解耦,整个PetShop,就是Linus说的围绕一堆“漂亮对象”建立起来的坚固堡垒,想要把箭楼换个位置? 除非你是秦始皇。 我一直反对Linus愤青式的言辞,但不得不说,是所有面向对象爱好者和一部分所谓“经典范例”,给了他们这些人口实。

    真正的自由和解耦,是视角和思想上的分离: 我们写下的每一行代码,都应该只基于上下文相关的概念,而不是任何形式的接口。这样需要变动的,就只剩下接口与概念之间的适配物了; 同时我们获得的就是真正意义上接口的自由: 从数据库/表/字段这些接口的变化,到这些数据可以转化为的任意一种对象所体现的接口的变化。

    在Linq大行其道的今天,这篇东西有点战斗檄文的意思,就不发首页了。我现在想法还很不成熟,但是深切感觉到这方面问题的兄弟们,如果你愿意了解我在这方面的想法,我一定想办法逐渐把它清晰化,一点一点的呈现出来。

    六祖慧能菩提本无树, 明镜亦非台; 本来无一物, 何处惹尘埃?
  • 相关阅读:
    第04组 beta冲刺(1/4)
    2019 SDN上机第5次作业
    SDN课程阅读作业(2)
    第04组 Alpha事后诸葛亮
    C Primer 复习题
    C Primer 编程练习
    C语言I博客作业04
    C语言I博客作业03
    C语言I博客作业02
    Appium + java截图方法
  • 原文地址:https://www.cnblogs.com/guaiguai/p/1099083.html
Copyright © 2020-2023  润新知