配置系统的设计与优化
1. 跳出简单配置的局限
在配置系统时,我们通常会将系统配置简化到最简形式。然而,配置系统也需要考虑高级用户的需求。以泡茶为例,如果我们需要特定的泡茶时长,该怎么办呢?
1.1 满足高级用户需求的策略
一种满足高级用户需求的策略是找到普通用户和高级用户需求的最小公倍数,并将该复杂度级别作为默认设置。但这种方法的缺点是会影响所有用户,即使是最简单的用例也需要从底层角度考虑。
另一种方法是通过可选的默认行为覆盖来进行配置。用户先配置“绿茶”,然后添加“泡茶五分钟”。在这种模式下,默认配置仍然是高级别的,接近用户的目标,但用户可以微调底层方面。这类似于高级编程语言,如 C++ 或 Java,允许程序员在高级语言编写的代码中包含机器(或虚拟机)指令。在一些消费软件中,我们也能看到带有高级选项的屏幕,提供比普通视图更精细的控制。
1.2 优化配置时间
在设计配置时,考虑整个组织的配置总时长是很有用的。不仅要考虑配置本身的操作,还要考虑用户面对众多选项时可能出现的决策瘫痪、走错路后纠正配置所需的时间、由于信心不足导致的变更速度变慢等因素。在考虑配置设计方案时,如果一个选项能以更少但更难的步骤完成复杂配置,且能显著简化最常见用例的支持,那么它可能更可取。
如果发现有相当一部分用户需要复杂配置,可能是错误地识别了常见用例。此时,应重新审视系统的初始产品假设,并进行额外的用户研究。
2. 配置的机制
2.1 分离配置和结果数据
存储配置使用哪种语言是不可避免的问题。可以选择使用纯数据格式,如 INI、YAML 或 XML
超级会员免费看
订阅专栏 解锁全文

被折叠的 条评论
为什么被折叠?



