当前位置:  开发笔记 > 编程语言 > 正文

设计以防止魔术数字和字符串

如何解决《设计以防止魔术数字和字符串》经验,为你挑选了0个好方法。

我正在构建一个从第三方检索并提交给第三方的服务.第三方提供了一个复杂的数据模型,其中包括三种不同的状态类型,所有这些类型的整数都有一个模糊的数字序列.下面提供了一个示例(键:值):

HandlerStatus          CustomerStatus   ArchiveStatus
---                    ---              ---
activeUnallocated:40   draftOpen:0      openOpen:0      
activeAllocated:26     submitted:2      closed:1
activePromoted:102     approved:100
Declined:2             declined:1
...                    ...

只有有限数量的组合,每个组合都有一个术语(提交,委托给另一个用户,等待确认等).例如:

Combination called "Submitted":
HandlerStatus has to be "activeUnallocated" (40)
CustomerStatus has to be "submitted" (2)
ArchiveStatus has to be "openOpen" (0)

我们可以期待添加其他值,并且用户友好名称可能会随时间而变化.
此外,还有一些操作,例如提交和委托给不需要用户选择新值的其他用户,这意味着服务需要知道在这些操作发生时必须设置的一组组合.

我必须能够为每种状态类型中的每个状态值定义用户友好的显示名称

我必须能够从用户接收新的状态值并映射正确的状态类型

我必须能够查找定义组合的值

我必须能够根据一组状态值查找定义的组合


我想到了三种不同的解决方案,各有利弊.

1.为每种状态类型定义en enum

优点:

强类型

维护仅限于一个文件

缺点:

枚举

UI表示的字符串格式


2.在外部JSON文件中定义键/值对

优点:

添加不需要更改代码

可以在运行时更新

缺点:

需要魔术字符串/数字用于具有相关组合的动作(没有用户输入的动作)

经常从文件系统中读取


3.为不同的可用状态组合创建代理类

优点:

强类型

灵活

缺点:

在第三方系统中发生更改时需要代码维护


我已经尝试研究最佳实践和模式,以确定哪种解决方案最适合,可维护性和良好的代码设计,但我没有得到任何地方(同时我在开发过程中严重依赖魔术字符串和数字) ).

推荐阅读
重庆制造漫画社
这个屌丝很懒,什么也没留下!
DevBox开发工具箱 | 专业的在线开发工具网站    京公网安备 11010802040832号  |  京ICP备19059560号-6
Copyright © 1998 - 2020 DevBox.CN. All Rights Reserved devBox.cn 开发工具箱 版权所有