我将bool打印到输出流,如下所示: #include iostreamint main(){ std::cout false std::endl;} 标准是否要求流上的特定结果(例如0表示错误)? 标准流有一个boolalpha标志,用于确定显示的内容 – 当它为假
#include <iostream> int main() { std::cout << false << std::endl; }
标准是否要求流上的特定结果(例如0表示错误)?
标准流有一个boolalpha标志,用于确定显示的内容 – 当它为假时,它们将显示为0和1.当它为真时,它们将显示为false和true.还有一个std :: boolalpha操纵器来设置标志,所以这个:
#include <iostream> #include <iomanip> int main() { std::cout<<false<<"\n"; std::cout << std::boolalpha; std::cout<<false<<"\n"; return 0; }
…产生如下输出:
0 false
对于它的价值,当boolalpha设置为true时产生的实际单词是本地化的 – 即< locale>有一个num_put类别来处理数字转换,所以如果你使用正确的语言环境灌输一个流,它可以/将打印出true和false,因为它们在该语言环境中表示.例如,
#include <iostream> #include <iomanip> #include <locale> int main() { std::cout.imbue(std::locale("fr")); std::cout << false << "\n"; std::cout << std::boolalpha; std::cout << false << "\n"; return 0; }
…至少在理论上(假设你的编译器/标准库接受“fr”作为“法语”的标识符)它可能会打印出faux而不是false.但是,我应该补充一点,对此的真正支持充其量是不均衡的 – 即使是Dinkumware / Microsoft库(在这方面通常相当不错)也会为我检查的每种语言打印错误.
使用的名称虽然在numpunct facet中定义,但是如果你真的希望它们能够正确地打印出特定的语言,你可以创建一个numpunct facet来做到这一点.例如,(我相信)法语至少相当准确的一个看起来像这样:
#include <array> #include <string> #include <locale> #include <ios> #include <iostream> class my_fr : public std::numpunct< char > { protected: char do_decimal_point() const { return ','; } char do_thousands_sep() const { return '.'; } std::string do_grouping() const { return "\3"; } std::string do_truename() const { return "vrai"; } std::string do_falsename() const { return "faux"; } }; int main() { std::cout.imbue(std::locale(std::locale(), new my_fr)); std::cout << false << "\n"; std::cout << std::boolalpha; std::cout << false << "\n"; return 0; }
结果是(正如你可能预期的那样):
0 faux