在使用 C++设计一个存储用户选项的结构体(类)时,往往会遇到 a 选项, b 选项等包含的信息数据不一致的问题。
如果为 a、b、c 等选项强行设计统一的数据结构体,再统一写处理逻辑。个人感觉比较困难:
所以,在业务没完全定型,在需要 quick and dirty 搞定该问题相关的业务时,个人认为联合体(union)适合处理该类问题。
举个例子: 假设有一个画图表的需求,用户有 2 个选项:
存储用户选择的数据结构中,a, b 中除了状态标志( is_auto_x )外,还有各选项独有的数据(本例体现在 b 选项会引入起始点 x_start,终止点 x_end,然而这些数据对 a 选项并无意义)。
定义选项数据如下
// 用户选项结构体
struct Cfg {
union X_Status {
bool is_auto_x; // a 选项相关数据
struct X_Range_Setting x_setting; // b 选项相关数据
} x_status; // 用此联合体表示互斥的选项
// ……其他数据和方法,略
};
// b 选项相关数据
struct X_Range_Setting {
bool is_auto_xrange; // 标志位统一
float x_start;
float x_end;
};
处理代码逻辑如下:
switch (x_status.is_auto_x) {
case true: // 处理用户 a 选项,具体访问`x_status.is_auto_x`
...; break;
case false: // 处理用户 b 选项,具体访问`x_status.x_setting`
...; break;
}
另外值得注意的是:
这 2 点 demo 里也有一点体现。
这是一个专为移动设备优化的页面(即为了让你能够在 Google 搜索结果里秒开这个页面),如果你希望参与 V2EX 社区的讨论,你可以继续到 V2EX 上打开本讨论主题的完整版本。
V2EX 是创意工作者们的社区,是一个分享自己正在做的有趣事物、交流想法,可以遇见新朋友甚至新机会的地方。
V2EX is a community of developers, designers and creative people.