领域驱动设计-柔性设计

 

为了使项目能够随着开发工作的进行加速前进,而不会由于它自己的老化停滞不前,设计必须要让人们乐于使用,而且易于作出修改。这就是柔性设计。

 

柔性设计是针对深层建模的补充。一旦我们挖掘出隐式概念,并把他们显示的表达出来之后,就有了原料。通过迭代循环,我们就可以把这些材料打造成有用的形式:建立的模型能够简单而清晰的捕获主要关注点;其设计可以让客户开发人员真正使用这个模型。在设计和代码的开发过程中,我们将获得新的理解,并通过这些理解改善模型概念。

 

1,释意接口(Ietention-Revealing-Interface)

主要解决沟通问题,强调要面向接口设计,而且接口及参数的命名一定要表达出意思来,这样调用者不会迷糊。还是那句话,写出人能看懂的代码。

  • 可以把关系和规则表述出来,但不要说明规则如何实施的。

  • 可以把事件和动作表述出来,但不要描述他们是如何执行的。

  • 可以给出方程式,但不要给出解方程式的数学方法。

  • 可以提出问题,但不要给出获取答案的方法。

 

2,无副作用方法(Side-Effect-Free Function)

此模式强调对一些值对象的操作一定不要产生副作用。值对象所有操作应该是无副作用的函数。

宽泛地把操作分为两大类别:命令和查询。

  • 查询是从系统获取信息,查询方式可能只是简单地访问变量中的数据,也可能是用这些数据执行计算。

  • 命令(也称为修改)是修改系统的操作(举一个简单的例子:设置变量)

返回结果而不产生副作用的操作称为函数。一个函数可以多次调用,每次调用都返回相同的值。尽可能把程序的逻辑放到函数中,严格地把命令隔离到不返回领域信息的,非常简单的操作中。

 

3,断言(Assertion)

此模式强调对“释意接口(Ietention-Revealing-Interface)”和“无副作用方法(Side-Effect-Free Function)”编写单元测试,以保证接口和函数无歧义。

 

4,概念轮廓(Conceptual Contour)

此模式强调把相关的操作,接口,类和聚合放在一起,使其更内聚,使其内部更加稳定。

 

5,独立类(Standalone Class)

此模式强调低耦合,把其他所有无关概念提取到对象之外,使其对象更加独立和理解。

相互依赖使模型和设计变得难以理解,测试和维护。而且互相依赖很容易越积越多。

Module和Aggregate的目的是为了限制相互依赖的关系网。

尽力把最复杂的计算提取到Standalone Class(独立类)中,实现此目的的一种方法是从存在大量依赖的类中将Value Object 建模出来。

 

6,闭合操作(Closure Of Operation)

闭合操作指方法的返回值和参数类型相同。

正如对整数的加减运算只会产生整数一样,如果模型中操作的返回值和参数是同一种类型的话,就可以不引入新的概念而描述这个操作。

大部分闭合操作都应该到Value Object 中去。

 

7,声明式设计

最好的声明式设计能够使开发人员不必去做那些单调乏味的工作,同时又完全不限制他们的设计自由。例如持久化和对象映射。

 

写在最后:

软件的最终目的是为用户服务。但首先它必须为开发人员服务。

 

上一篇领域驱动设计-模型驱动设计的构造块

参考:《领域驱动设计》  Eric Evans [美]

分布式架构 漫谈分布式架构 初识分布式架构与意义 如何把应用从单机扩展到分布式 大型分布式架构演进过程 分布式架构设计 主流架构模型-SOA架构和微服务架构 领域驱动设计及业务驱动规划 分布式架构的基本理论CAP、BASE以及其应用 什么是分布式架构下的高可用设计 构架高性能的分布式架构 构建分布式架构最重要因素 CDN静态文件访问 分布式存储 分布式搜索引擎 应用发布与监控 应用容灾及机房规划 系统动态扩容 分布式架构策略-分而治之 从简到难,从网络通信探究分布式通信原理 基于消息方式的系统间通信 理解通信协议传输过程中的序列化和反序列化机制 基于框架的RPC通信技术 WebService/ApacheCXF RMI/Spring RMI Hession 传统RPC技术在大型分布式架构下面临的问题 分布式架构下的RPC解决方案 Zookeeper 分布式系统的基石 从0开始搭建3个节点额度zookeeper集群 深入分析Zookeeper在disconf配置中心的应用 基于Zookeeper Watcher 核心机制深入源码分析 Zookeeper集群升级、迁移 基于Zookeeper实现分布式服务器动态上下线感知 深入分析Zookeeper Zab协议及选举机制源码解读 Dubbo 使用Dubbo对单一应用服务化改造 Dubbo管理中心及及监控平台安装部署 Dubbo分布式服务模块划分(领域驱动) 基于Dubbo的分布式系统架构实战 Dubbo负载均衡策略分析 Dubbo服务调试之服务只订阅及服务只注册配置 Dubbo服务接口设计原则(实战经验) Dubbo设计原理及源码分析 基于Dubbo构建大型分布式电商平台实战雏形 Dubbo容错机制及扩展性分析 分布式解决方案 分布式全局ID生成方案 session跨域共享及企业级单点登录解决方案实战 分布式事务解决方案实战 高并发下的服务降级、限流实战 基于分布式架构下分布式锁的解决方案实战 分布式架构实现分布式定时调度 分布式架构-中间件 分布式消息通信 消息中间件在分布式架构中的应用 ActiveMQ ActiveMQ高可用集群企业及部署方案 ActiveMQ P2P及PUB/SUB模式详解 ActiveMQ消息确认及重发策略 ActiveMQ基于Spring完成分布式消息队列实战 Kafka Kafka基于Zookeeper搭建高可用集群实战 kafka消息处理过程剖析 Java客户端实现Kafka生产者与消费者实例 kafka的副本机制及选举原理剖析 基于kafka实现应用日志实时上报统计分析 RabbitMQ 初步认识RabbitMQ及高可用集群部署 详解RabbitMQ消息分发机制及主题消息分发 RabbitMQ消息路由机制分析 RabbitMQ消息确认机制 Redis redis数据结构分析 Redis主从复制原理及无磁盘复制分析 Redis管道模式详解 Redis缓存与数据库一致性问题解决方案 基于redis实现分布式实战 图解Redis中的AOF和RDB持久化策略的原理 redis读写分离架构实践 redis哨兵架构及数据丢失问题分析 redis Cluster数据分布算法之Hash slot redis使用常见问题及性能优化思路 redis高可用及高并发实战 缓存击穿、缓存雪崩预防策略 Redis批量查询优化 Redis高性能集群之Twemproxy of Redis 数据存储 MongoDB NOSQL简介及MongoDB支持的数据类型分析 MongoDB可视化客户端及JavaApi实践 手写基于MongoDB的ORM框架 MongoDB企业级集解决方案 MongoDB聚合、索引及基本执行命令 MongoDB数据分片、转存及恢复策略 MyCat MySQL主从复制及读写分离实战 MySQL+keepalived实现双主高可用方案实践 MySQL高性能解决方案之分库分表 数据库中间件初始Mycat 基于Mycat实习MySQL数据库读写分离 基于Mycat实战之数据库切分策略剖析 Mycat全局表、Er表、分片预警分析 Nginx 基于OpenResty部署应用层Nginx以及Nginx+lua实战 Nginx反向代理服务器及负载均衡服务器配置实战 利用keepalived+Nginx实战Nginx高可用方案 基于Nginx实现访问控制、连接限制 Nginx动静分离实战 Nginx Location ReWrite 等语法配置及原理分析 Nginx提供https服务 基于Nginx+lua完成访问流量实时上报Kafka的实战 Netty 高性能NIO框架 IO 的基本概念、NIO、AIO、BIO深入分析 NIO的核心设计思想 Netty产生的背景及应用场景分析 基于Netty实现的高性能IM聊天 基于Netty实现Dubbo多协议通信支持 Netty无锁化串行设计及高并发处理机制 手写实现多协议RPC框架
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值