我正在重新设计一个C++类的构造函数,需要捕获未指定的bool值。我已经为所有其他参数使用了默认值,但据我了解,bool类型只能被初始化为true或false。由于这两种情况在类中都有意义,那么我应该如何处理检查默认值是否更改的情况呢?
现实情况是你无法做到这一点。bool类型具有值,即true或false,如果你没有初始化它,那么它将随机地变成true或false,可能在程序的每次运行或类的分配时都不同。
如果你需要一个具有更多选项的类型,请定义一个枚举。
typedef enum MyBool {
TRUE,
FALSE,
FILENOTFOUND
} MyBool;
三态布尔是通往黑暗面的道路。三态布尔会导致愤怒。愤怒导致仇恨。仇恨导致痛苦。
最好不要使用三态布尔。
相反,使用一个额外的布尔值来确定第一个布尔值是否已经“初始化”(或更好地说是“已知”)。
class Prisoner : public Person
{
...
bool is_veredict_known;
bool is_guilty;
}
如果还不知道判决结果,你无法确定被告是否真的有罪,但你的代码可以区分不同的情况。当然,宪法保证is_guilty的默认值应该是false,但是...... :)
顺便说一下,类不变式应该包括:
assert(is_veredict_known || !is_guilty);
看起来你需要 boost::tribool 或者可能是 boost::optional<bool>。
template <typename T>
struct Maybe {
Maybe() : m_hasValue(false) {}
bool HasValue() const { return m_hasValue; }
T& Value() { ThrowIfFalse(m_hasValue); return m_value; }
const T& Value() const { ThrowIfFalse(m_hasValue); return m_value; }
void SetValue( _In_ const T& value) { m_value = value; m_hasValue = true; }
private:
bool m_hasValue;
T m_value;
};
class SomeType {
...
Maybe<bool> m_myBool;
}
bool
只有一位信息,要么是0,要么是1。由于您想表示三种可能的状态,因此需要更多的信息位。有两种常见的技术:
bool
值来指示该值是否为“默认值”,或者使用优秀的boost::optional。不仅适用于布尔值,而且适用于您在其他地方使用了一些未初始化的脏数值。其使用方式如下:
void function(optional<int> value) {
if (value)
std::cout << "value is defined: " << value.get() << "\n";
else
std::cout << "value is not defined\n";
}
以下是一个返回可选项的函数示例:
struct MapClass {
map<string,int> m_map;
optional<int> getValue(string key) {
optional<int> result = none;
if (m_map.find(key) != m_map.end())
result = m_map[key];
return result;
}
}
struct Bool { //guaranteed initialized bool
bool v;
Bool() : v(false) {}
operator bool() const { return v; }
bool& operator=(const bool val){ return v = val; }
};
你可以拥有一个单独的私有成员来表示布尔值是否已经被初始化。
你真的不能这样做。你可以提供第二个构造函数,例如:
class MyClass {
public:
MyClass(bool bFlag); // <-- not default
MyClass(void); // <-- default
};
我不太明白,但我会尝试...
当您有一个聚合初始化程序留下一些值未指定时,将应用默认值。在这种情况下,bool的默认值将为false。在类中,“默认”值将未初始化,这意味着它可以是任何值,并且可以从运行到运行更改。
如果您对bool是否已更改感兴趣,则最好使用第二个bool跟踪它,默认为false,或使用表示3种可能状态的枚举。如果您真正想要3种状态,那么您真的不需要一个bool。