草庐IT

c++ - std::deque 什么时候需要重新分配?

据我所知,std::deque以block的形式存储它的元素(虽然它依赖于实现,但这是我在大多数来源中读到的)而不是std::vector在大多数情况下使用单个内存块。因此,std::vector在插入过程中遇到重新分配是很合理的。但是,我无法将需要为std::deque重新分配的任何情况联系起来,因为当电流耗尽时,它只是从新的内存块开始。任何人都可以向我提供一个案例,其中std::deque由于对其执行了某些操作而需要重新分配吗? 最佳答案 Cananyoneprovidemewithcasewherestd::dequeneed

c++ - 为什么 std::max 由 const 返回?

我想找到最大值Foo并对其调用inc(),这是一个非常量方法。当然,在寻找最大值时,我不想创建任何拷贝或移动,即我不想要Foofoo=std::max(foo1,foo2)。我尝试编写自己的max,但g++坚持要我返回一个const&。#includeclassFoo{public:Foo(intx):x_(x){std::cout(constFoo&foo)const{returnx_>foo.x_;}voidinc(){++x_;}intx_;};/**Doesn'tcompile.MustreturnconstT&ormustacceptnon-constT&*templatei

c++ - 使用 std::get 作为 std::transform 的参数

我可能在这里遗漏了一些明显的东西——为什么我不能以这种方式使用std::get?#include#include#include#include#includeintmain(){std::mapsome_map;std::setset_of_ints;std::transform(some_map.begin(),some_map.end(),std::inserter(set_of_ints,set_of_ints.begin()),std::get);return0;}我试过的编译器是VS2010以及Ideone.com用于C++14的任何编译器(一些最近的GCC?)。这是后者的

c++ - 关联 std::tuple 容器

是否有可能定义(以一种简单的方式,可能重新使用std容器)“associativestd::tuple”,或者换句话说“variadiacstd::map”。类似这样的东西(这个接口(interface)只是为了解释,欢迎其他可能的接口(interface)):AssociativeTupleat;//std:stringisthekeytypeat.insert("my_float",3.14);//1.at.insert("my_int",42);at.insert("my_bool",true);at.insert("xyz",0);at.insert("my_string","

c++ - 为什么 Eclipse 不使用 GDB 的 pretty-print ?

我在Ubuntu14.04和GDB7.7.1上使用Eclipse4.4.2。我正在尝试在Eclipse调试器中检查一些C++标准库容器的内容。到目前为止我已经尝试过:按照说明进行操作here,我运行了命令svncosvn://gcc.gnu.org/svn/gcc/trunk/libstdc++-v3/python将其复制到/home/myusername/prettyprint。然后我将此文本复制到我的.gdbinit中:pythonimportsyssys.path.insert(0,'/home/myusername/prettyprint/python')fromlibstdc

C++、信号和线程

我在使用线程和信号设计我的应用程序的主要工作流程时遇到了一些困难。我的目标是有一个主线程,捕捉信号,n个其他线程周期性地做一些事情(实际上是在树莓派上使用传感器,并保存检索到的数据)。我希望能够以干净的方式关闭程序,即等待传感器完成写入数据(如果它们在信号发生时),然后再关闭它。我正在使用C++11。现在,我有这个例子:#include#include#include#include#defineNUM_THREAD3;staticvolatileintstop=0;//Ifthethreadsneedstostopstd::mutexm;//MutexvoidthreadHandle

c++ - 处理从 boost 序列化中删除的变量

我查看了网络上关于通过递增版本号并在该变量的序列化周围添加“if”来向序列化函数添加成员变量的示例。但是如果我删除了一个成员变量,我该怎么办呢?我是否应该将它从序列化函数中删除,然后boost会处理它?如果我删除了一些在序列化函数中“序列化”的类,情况可能会变得更糟,我是否需要只为该序列化代码保留它们,还是有其他方法? 最佳答案 后台/存档格式兼容性BoostSerialization在很多情况下都非常轻量级。具体来说,如果您不使用对象跟踪/动态多态性,那么在使您的序列化流兼容时会有惊人的回旋余地。在通过(智能)指针(指向基址)进行

c++ - std::string::reserve() 和 std::string::clear() 难题

这道题从一段代码开始,只是因为我觉得这样更容易看出我在追求什么:/*static*/voidUrl::Split(std::list&url,conststd::string&stringUrl){std::stringcollector;collector.reserve(stringUrl.length());for(autoc:stringUrl){if(PathSeparator==c){url.push_back(collector);collector.clear();//Sabotagesmyoptimizationwithreserve()above!}else{col

c++ - 在用它执行算术时隐式地将对象转换为浮点类型

假设我们有一个全局对象pi,我们想根据上下文将其隐式转换为float或double。以下不起作用:#includeclassPi{public:Pi(){}operatorfloat()const{returnstd::atan(1.0f)*4.0f;}operatordouble()const{returnstd::atan(1.0)*4.0;}};constPipi;#include#includeintmain(){std::cout它不起作用的原因是编译器不知道它是否应该将pi隐式转换为float或double.但是,假设我们总是希望它在二元算术运算符中转换为另一个操作数的类型

c++ - {} 是传递给需要迭代器(代表某个容器的 std::end() )的函数的有效参数吗?

在boostdirectory_iteratorexample-howtolistdirectoryfilesnotrecursive(参见thisanswer)中是示例代码#include#include#include...usingnamespaceboost::filesystem;for(auto&entry:boost::make_iterator_range(directory_iterator(p),{})){std::cout(p是boost::filesystem::path类型。)在查看documentationformake_iterator_range时,我认