领域驱动设计学习笔记(一)

谈到领域驱动设计,简简单单的六个字,却包含了两个关键点:一个是“领域”,另一个是“设计”。“驱动”一词,则对两个名词(关键点)的关系进行了定义。左思右想,“驱动”一词好像是二者间关系一个现在看来最为恰当的描述,无可替代——既不是领域强制性决定如何去设计,又不是设计可以凌驾于领域之外的无关紧要,而是一种平行的,互为依托的关系。没有设计的领域毫无意义,而没有领域的设计也只是纸上谈兵。

似乎,对领域(模型)的设计,是对一件艺术品的仔细雕琢一般。

我开始学习领域驱动设计,源动力在于撸代码时的绝望。

对,就是绝望。

冗长而不知其意的名称,无穷无尽的 setter/getter。我仿佛一眼便看到了世界的尽头。就像现在你,不幸看到我这冗长、无聊、不知所云的开头一般。

就问你,累不累?烦不烦?绝不绝望?

绝望也要看下去。别问我为什么。从现在开始,在你的世界里,没有为什么。

好了,言归正传。

领域驱动设计中,最为关键的两个核心点,或者称之为支柱的便是 <strong>限界上下文</strong> 和 <strong>通用语言</strong>。

一直很奇怪老外的语法形式,又间接对国内整体翻译水平产生了怀疑。

在我看来,限界上下文倒不如称为 <strong>语境</strong>(上下文是具象的,语境才是抽象的好不好?)。

通用语言,就是在语境中能说得通,说顺溜,不会产生明显歧义(怪我大中华文化博大精深咯)的一个词、一句话。

看到这里,你应该觉着这玩意儿时骗人的吧。这样想就对了,没这样想就试着想想。

其实,一开始我也是这么想的。一个词、一句话、一段文,外加一个语境,就能搞出什么鬼设计来?

还真别说,举个简单的例子,亮瞎你的 24K 纯钛合金 dog 眼:

试着设计一个我们常见的Class:User

public class User {

    private String username;

    public void setUsername(String username) {
        this.username = username;
    }

    public String getUsername() {
        return this.username;
    }
}

试着用一个 User 实例化对象调用他的 getUsername()方法:

public class Main {

    public static void main(String[] args) {
        User user = new User();
        String username = user.getUsername();
    }
}

传统的调用方法大概就是这样吧。

不论其他,请您给我顺畅地用中文将 user.getUsername() 翻译过来。

我的翻译是这样的:用户(user)得到(get)Username(用户名)。
so easy, <strong>用户得到用户名</strong>。

发现问题没有?没有?回幼稚园重新回炉深造去。好吧,开个玩笑,重来一次,还是上面的模式:将 User 替换成 You:

public class You {

    private String name;

    public void setName(String name) {
        this.name = name;
    }

    public String getName() {
        return this.name;
    }
}

试着用一个 You 实例化对象调用他的 getName()方法:

public class Main {

    public static void main(String[] args) {
        You you = new You();
        String name = you.getName();
    }
}

首先声明,以上这个例子只在于说明问题。

就问你,发现问题没?还没发现?对不起,不开玩笑的说,请您出门右转,祖国的花儿幼稚园欢迎您!

慢走不送,下次也别再来了。

什么鬼嘛?<strong>你得到名字</strong>。

你需要得到你的名字吗?需要吗?需要吗?需要吗?

不需要!

你的名字是你出生后父母给你起的,中间即使可能更名(换姓的请举手),但你从来都不需要去“得到你的姓名”。除非你患上了“失忆症”。但,即使如此,你也应该调用 AmnesicPatients#whoami()。

好,话题继续回到领域驱动设计上。说到底,领域驱动设计就是用来解决不合理:包名不合理、类名不合理、属性名不合理、方法名不合理、方法位置不合理、调用不合理、程序奔溃不合理......

没有包治各种不合理(起码李家孩子和隔壁老王同姓这种不合理是真没辙),毕竟,凡事都有妥协与余地,但总归大部分不合理可以得到根治。况且,一切都合理才是最大的不合理。

继续 User 这个例子,这个是改进版的:

public class User {

    private String username;

    public void setUsername(String username) {
        this.username = username;
    }

    public String username() {
        return this.username;
    }
}

public class Main {

    public static void main(String[] args) {
        User user = new User();
        user.username();
    }
}

现在的调用是不是合理多了:<strong>用户的用户名</strong>

public class You {

    private String name;

    public void setName(String name) {
        this.name = name;
    }

    public String name() {
        return this.name;
    }
}

public class Main {
    public static void main(String[] args) {
        You you = new You();
        you.name();
    }
}

<strong>你的名字</strong>

别问我“的”是哪儿来的, ‘.’ 即是“的”,“的”即是 ‘.’ 。

不要怀疑,即使将现在的论调拿到过去旧的案例,旧案例的调用依旧不合理:用户的得到用户名(得到用户名的用户)、你的得到名字。

八格牙路。你的良心大大地坏了。

其实,初识 DDD(Domain Drive Design · 领域驱动设计)觉得最难的也就是对什么“限界上下文”(语境)和“通用语言”(在某一语境中尽最大可能无歧义的词、句)了。所以......

上面讨论的,其实基本都是属于通用语言范畴,至于语境(限界上下文),我真不知道该怎么描述,难道是,见人说人话,见鬼说鬼话——同样的人,在不同的环境下,会有不同的表现形式。一个同样名称的 Class,在不同的业务系统中就有可能描述了不同的两种事物?

好吧,贱人贱智了!

《实现领域驱动设计》中,谈到通用语言是,业务专家和开发者等一群对相关业务或技术熟悉的人,进行反复讨论后,互相补充后达成一致的产物。

所以说。。。那啥,刚才出门右转的朋友,你可以学成归来了。

PS:行文风格有点骚(我这老脸),不喜轻喷!

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 160,026评论 4 364
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 67,655评论 1 296
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 109,726评论 0 244
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 44,204评论 0 213
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 52,558评论 3 287
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 40,731评论 1 222
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 31,944评论 2 314
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 30,698评论 0 203
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 34,438评论 1 246
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 30,633评论 2 247
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 32,125评论 1 260
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 28,444评论 3 255
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 33,137评论 3 238
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 26,103评论 0 8
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 26,888评论 0 197
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 35,772评论 2 276
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 35,669评论 2 271

推荐阅读更多精彩内容