领域驱动设计-软件挑战与应对

通常我们在进行大型软件开发和互联网产品研发过程中,会遇到很多的挑战与问题:

1.未使用通用语言分析需求

我们通常拿到客户的需求后,会分析这个需求,在分析需求的过程中,我们通常与客户和产品经理用不同的语言在描述需求。

比如产品经理会有产品需求说明书或原型跟我们谈,我们自己在脑海中会不自觉地有一些技术素语与他们交谈,这样会造成没有重点关注业务问题,双方说不到一块。

2.架构缺乏的代码大泥球

我们开发出来的产品架构混乱,业务逻辑代码、数据库访问代码等分布在系统的各个角落,后期维护困难,而且定位BUG也绝非易事。

3.缺乏问题域的关注

架构师和开发人员通常容易陷落到如何通过技术实现,太关注技术实现细节,而没有从宏观层面理解产品要解决的业务问题。

面对这些问题和挑战,我们应该这样应对:

1.提炼问题域

要确定产品要解决的核心问题是什么。

2.创建领域模型解决问题

通常通过分析模型与代码模型来解决业务问题。分析模型是我们对业务需求分析的结果,在实际的工作中,在和客户或产品经理分析需求的过程中,可以采用分析模型

这样的统一语言进行工作,我们在平时的过程中,客户和产品经理一般是能够看懂我们的分析模型的,但要注意,分析模型更多描述业务信息和关系,不要太多牵扯到

技术方面的实现细节。

3.建模协作

在建立分析模型的过程中,我们可以和客户或产品经理不断迭代这个模型,可以从粗(建立关键业务类、属性和之间的主要关系)到细(所有类、所有的属性)来做,不要一步

到位,也不要在初次建立分析模型时要求一步到位。

4.确定上下文和信息交互

要根据产品要解决的问题分为几个子业务系统,也就是多个上下文,然后确定每个上下文之间信息交互的方式。下个部分的战略建模会详细谈这个方面的内容。

本文参与腾讯云自媒体分享计划,欢迎正在阅读的你也加入,一起分享。

发表于

我来说两句

0 条评论
登录 后参与评论

相关文章

来自专栏SDNLAB

DevOps:新的业务浪潮

DevOps是一种基于将敏捷和精益哲学应用于运营工作的新业务,过去,运营和研发工程师在不同的领域工作,DevOps完全改变了这一状况,两者在整个生命服务周期中紧...

35650
来自专栏云计算D1net

当大数据分析与云技术双剑合璧

大数据的出现使业务智能真正地走入了21世纪。但事实上“大数据”词代表的并不是解决方案,而是一类问题。在这些PB数量级的数据中,隐藏着怎样的价值?我们从中能...

29070
来自专栏华章科技

腾讯发布2017年代码报告

腾讯发布2017年代码报告,对过去一年研发数据进行了统计,涵盖代码、开发者、语言等基础数据。

10350
来自专栏WeTest质量开放平台团队的专栏

WeTest腾讯质量开放平台内测开启

WeTest腾讯质量开放平台(wetest.qq.com)于2015年1月22日开启内测。

19420
来自专栏钱塘大数据

《2017微信数据报告》发布,这数据很“大”!

作者:腾讯 11月9日消息 今天腾讯官方发布了最新的《2017微信数据报告》,根据腾讯公布的数据,微信在国内已经成为首屈一指的聊天软件。报告核心数据如下: 1...

74790
来自专栏PPV课数据科学社区

【资讯】甲骨文融合中间件即服务满足企业云需求

甲骨文公司亚太及日本区融合中间件管理高级总监李国东 像所有新概念一样,“大数据”经历过一段炒作期后,已经被企业所普遍接受。IDC的报告显示:全球...

29860
来自专栏大数据文摘

中国移动社群生态报告(下载39PPT)

287110
来自专栏日志易的专栏

@三斗室 饶琛琳“大话”运维安全

运维安全是企业安全保障的基石,不同于Web安全、移动安全或者业务安全,运维安全环节出现问题往往会比较严重。

36310
来自专栏ThoughtWorks

敏捷中的QA

作者 林冰玉 说到QA,通常指的是质量保证(Quality Assurance)工程师,但我更喜欢定义敏捷中的QA为质量分析师(Quality Analyst...

37470
来自专栏WeTest质量开放平台团队的专栏

用上WeTest适配测试,流失用户减少一半!

为什么需要适配测试? 近期,腾讯游戏工作室对近2000名流失玩家进行了一次问卷调查活动。

13220

扫码关注云+社区

领取腾讯云代金券