草庐IT

boost-date-time

全部标签

c++ - boost shared_ptr 运算符 =

这里是代码示例classA{inti;public:A(inti):i(i){}voidf(){prn(i);}};intmain(){A*pi=newA(9);A*pi2=newA(87);boost::shared_ptrspi(pi);boost::shared_ptrspi2(pi2);spi=spi2;spi->f();spi2->f();pi->f();pi2->f();}输出:8787087问题是为什么输出中是0?文档注释:效果:等同于shared_ptr(r).swap(*this)。但是如果shared_ptr对象刚刚交换,结果应该是9。如果第一个对象被删除,应该有S

c++ - boost::spirit::qi 对输出进行重复解析

我有一个使用Boost::Spirit的非常简单的解析器:rulezeroTo255=(string("25")>>char_('0','5'))|(char_('2')>>char_('0','4')>>digit)|(char_('1')>>repeat[2](digit))|(char_('1','9')>>digit)|digit;当我尝试解析时std::stringo{"1"};std::strings;parse(o.begin(),o.end(),zeroTo255,s);std::cout我有输出1:111我显然做错了什么,但是什么? 最佳答

c++ - (伪)-行列式为零的 N×N 矩阵的逆

我想在我的GraphSlam中使用nxn矩阵的逆矩阵。我遇到的问题:.inverse()Eigen库(3.1.2)不允许零值,返回NaNLAPACK(3.4.2)库不允许使用零行列式,但允许零值(使用来自ComputingtheinverseofamatrixusinglapackinC的示例代码)Seldon库(5.1.2)由于某种原因无法编译有没有人成功实现了允许负数、零值和零行列式的nxn矩阵求逆代码?有什么好的库(C++)推荐吗?我尝试为GraphSlam计算以下omega:http://www.acastano.com/others/udacity/cs_373_autono

c++ - 打印 boost 属性树生成的 xml

我测试了boost::property_tree,结果很好:我可以加载XML、提取元素、保存XML等。但是,是否可以生成XML并打印它?我不想保存它。voiddebug_settings::load(conststd::string&filename){usingboost::property_tree::ptree;ptreept;read_xml(filename,pt);m_file=pt.get("debug.filename");m_level=pt.get("debug.level",0);BOOST_FOREACH(ptree::value_type&v,pt.get_c

c++ - boost.pool 是如何实现分配内存的重用呢?

背景我的previousquestion关于boost.pool让我详细研究了boost.pool,现在我有一个补充问题来完成我的理解。序曲Thisreference声明以下关于对象池模式:Theobjectpoolpatternisasoftwarecreationaldesignpatternthatusesasetofinitializedobjectskeptreadytouse,ratherthanallocatinganddestroyingthemondemand.据我所知,boost.pool(简化版)通过主要基于element_type大小的内存分配和管理实现对象池模

c++ - boost::optional 的比较 (<)、输出 (<<) 和赋值 (=)

我有几个关于如何boost::optional的问题作品。让我们首先这样做:boost::optionali;是i总是等于*i(和其他关系运算符类似)?条件是否正确i和*i未定义?(i仍未设置任何值)什么是std::cout应该打印吗?我很确定i=3始终与*i=3相同.如果是这样,我应该更喜欢哪个? 最佳答案 没有。如果i未初始化,第一个将返回true,而第二个将断言。没有。operator的文档清楚地表明,如果左侧参数未初始化,它将返回true设置右手操作数时。没有operator对于optional所以我假设它会返回unspec

c++ - 如何在不使用 boost 或创建模板的情况下在 C++ 中同时对两个 vector 进行排序?

我有两个大小相同的vectorvectorpredictions;//say{1.22,3.22,2.22,4.22}vectorindices;//say{0,1,2,3}我使用降序对预测中的值进行排序std::sort(predictions.rbegin(),predictions.rend());//gives{4.22,3.22,2.22,1.22}现在我想在预测的同时对索引进行排序。//toget{3,1,2,0}如何在不使用提升和自定义模板的情况下做到这一点? 最佳答案 您可以将这两个vector合并为一个类型,如st

c++ - 链接到 boost_thread 的问题

我正在尝试将xubuntu上的boost1.47与gcc4.6和glibc2.13链接起来。到目前为止,我无法编译以下简单程序main.cpp:#include#include#includeintmain(){size_tn_threads=boost::thread::hardware_concurrency();return0;}当我编译时:g++-lboost_thread-lboost_regex-omcmain.cpp-static-lpthread/usr/local/lib/libboost_regex.a/usr/local/lib/libboost_thread.a

c++ - 使用 Visual Studio 获取 time_t 的最大值

我需要独立于以下代码工作平台:timevaltv;tv.tv_sec=std::numeric_limits::max();此代码在各种LinuxOS和MacOSX下都能正常工作。不幸的是,在Windows下,对于tv.tv_sec这将返回-1。然后我想像这样重新定义time_t:typedefinttime_t;这也不起作用,因为编译器现在提示:errorC2371:'time_t':redefinition;differentbasictypes我怎样才能让这段代码独立于平台运行? 最佳答案 tv.tv_sec=std::num

C++ 模板 : How to put nontype constraints in compiling time

假设我有以下模板templateclassFOO{....}事实上,我要求(I>=F)。如果有人误用FOOa;我希望提出一个编译错误。如何做到这一点?谢谢 最佳答案 一种方法可能是C++11的static_assert,它类似于assert,但在编译时检查:templateclassFOO{static_assert(I>=F,"IneedstobelargerorequaltoF");...}; 关于C++模板:Howtoputnontypeconstraintsincompiling