草庐IT

VARIANT_BOOL

全部标签

c++ - libstdc++ 的 std::vector<bool>::data 有什么作用?

根据标准,std::vector没有成员函数data().但是,以下代码片段可以使用带有libstdc++的最新GCC正常编译:#includeintmain(){std::vectorv;v.data();}如果我们尝试使用结果,结果返回类型是void.这是一些gcc扩展还是一个错误?如果前者为真,它有什么作用? 最佳答案 我的/usr/include/c++/4.8/bits/stl_bvector.h有://_GLIBCXX_RESOLVE_LIB_DEFECTS//DR464.Suggestionfornewmemberfu

c++ - 是否可以使用包含 boost::variant 的 STL 容器并在变体类型本身中使用相同的容器类型?

这似乎是不可能的,但我还是想问问。我定义了一个boost::variant像这样:typedefboost::variantConfigVariant;稍后在我的代码中我定义了一个std::map像这样:std::mapmy_map;现在我希望能够拥有std::map里面的值my_map.例如,我想这样做:my_map[key1][key2]="helloworld";我认为这是不可能的原因是因为相应的变体定义看起来像这样:typedefboost::variantConfigVariant;既然不可能进行这样的类型定义,那么有什么办法可以解决这个问题吗?

c++ - 普通默认可构造的 std::optional 和 std::variant

可以设计吗std::optional(当前std::experimental::optional)以这种方式,对于普通的默认可构造类型T对应std::optional也是默认可构造的吗?同样的问题重新阅读std::variant及其积分判别器。我自己的回答是:“不行,不能这么设计,因为如果对象有自动存储期,或者是非reinterpret_cast-ed,默认初始化时得到的它的整数鉴别器的值是不确定的-零初始化存储。”要求用户每次都进行值初始化在我看来是不允许的。 最佳答案 您的回答是正确的:不能。规范要求在默认构造时将其“初始化标志

c++ - 我需要 std::atomic<bool> 还是 POD bool 足够好?

考虑这段代码://globalstd::atomicrun=true;//thread1while(run){/*dostuff*/}//thread2/*dostuffuntilit'stimetoshutdown*/run=false;我在这里需要与原子变量相关的开销吗?我的直觉是,bool变量的读/写或多或少是原子的(这是一个常见的g++/Linux/Intel设置),如果有一些写/读时序异常,我在线程1上的运行循环会停止一个结果是早晚通过,对于这个应用程序我不是很担心。还是我在这里遗漏了一些其他考虑因素?查看perf,我的代码似乎在std::atomic_bool::opera

c++ - 获取一个 std::tuple 元素作为 std::variant

给定一个变体类型:usingVariant=std::variant;和一个包含仅限于此变体类型的元素的元组类型(重复和遗漏是可能的,但没有其他类型):usingTuple=std::tuple;如何实现在运行时通过给定索引获取和设置元组元素的方法作为Variant:VariantGet(constTuple&val,size_tindex);voidSet(Tuple&val,size_tindex,constVariant&elem_v);我的代码中有两个实现,但我觉得可以有一个更好的实现。我的第一个实现使用std::function,第二个实现构建了一些Accessor指针的数组

c++ - 使用 boost::tuple<bool, T> 来指示是否找到 T 是否好?

假设我们需要一个返回值的函数。但是那个东西是找不到的。我看到选项:1.Tfind(bool&ok);//returndefaultTvalueifnotfound我们可以创建一个结构体:templateclassCheckableValue{public:CheckableValue(),_hasValue(false){}CheckableValue(constT&t):_value(t),_hasValue(true){}inlineboolhasValue()const{return_hasValue}constT&value()const{assert(hasValue());

c++ - 对 null 对象的函数调用返回的 bool 值

在C++中对空对象进行函数调用时返回的bool值是什么?ClassDummy*dummy=NULL;if(!dummy->dummy_function(1,2,3)){//DoSomething}根据C++11标准,这不应该返回错误吗? 最佳答案 除非dummy已在命名空间范围内声明,否则它未初始化且其值未指定,即它可能为null也可能不为null。在nullptr或指向无效内存的指针上调用成员函数是未定义的行为。你可能getawaywiththecorrectresult如果您调用的成员函数不访问该类的任何其他数据成员;换句话说,

c++ - C++ 编译器可以假定 const bool & value 不会改变吗?

C++编译器能否假定“constbool&”值不会改变?例如,假设我有一个类:classtest{public:test(constbool&state):_test(state){}voiddoSomething(){if(_test){doMore();}}voiddoMore();private:constbool&_test;};我按如下方式使用它:voidexample(){boolmyState=true;testmyTest(myState);while(someTest()){myTest.doSomething();myState=anotherTest();}}标准

c++ - 一元减号运算符如何在 C++ 中处理 bool 值?

我目前正在将一些OpenCV代码从C++转换为Java。我不能使用JavaCV,因为我们需要在nativeJava中进行转换,而不是JNA。在代码的某个位置,我得到了以下分配:dst[x]=(uchar)(-(kHit>=kForeground));其中dst是uchar*,kHit和kForeground是int.我一直无法找到有关其工作原理的任何信息,并且Java不会将其识别为操作。在代码的另一处对这两个变量进行了操作,它存储了两个值之一:255或0。问题代码来自opencv/video/src/bgfg_gaussmix.cpp。 最佳答案

c++ - 在 C++ 中,使用 bool 而不是 char 有什么意义?

sizeof(char)和sizeof(bool)都等于1(在我的编译器/系统/不管怎样,我听说它并不总是相同的值),bool只能存储true或false,而char可以取更多的值,并且可以使用按位运算符充当多个bool变量(8位,每个位可以用作1个bool,总共8个bool)那么使用bool代替char有什么优势吗?那么除了可读性之外还有别的吗?我在某处读到,即使占用更多内存,int的处理速度也比short或byte快。char和bool在速度上有什么区别吗? 最佳答案 使用bool的要点是表达意图。如果变量旨在存储具有true/