草庐IT

boost-function

全部标签

c++ - 将整数类型转换为枚举 : functional cast vs initialization

假设有一个这样的枚举:enumfoo:int{first,second}然后我使用它如下:foof(1);//error:cannotinitializeavariableoftype'foo'withanrvalueoftype'int'foof=foo(1);//OK!我想知道这两者有什么区别?我知道第二个版本可以看作是函数式转换,但为什么这会有什么不同?例如,如果我这样做:classBar{};Barb=Bar(1);//nomatchingconversionforfunctional-stylecastfrom'int'to'Bar'我显然得到了一个有意义的错误。因此,这让我

c++ - 如何使用 boost-range 在函数中封装自定义迭代器

最近我使用boost-range来创建满足特定条件的元素的范围。在所有情况下,我一直使用相同类型的过滤范围,因此我试图将此行为封装在外部函数中。这就是我的问题开始的地方。考虑以下示例。#include#include#includeautomyFilter=[](conststd::vector&v,intr){returnv|boost::adaptors::filtered([&r](autov){returnv%r==0;});};intmain(intargc,constchar*argv[]){usingnamespaceboost::adaptors;std::vector

C++ boost::multi_array 索引太大

我正在使用二维boost::multi_array来存储自定义结构的对象。问题是我有大量的这些对象,所以我需要的数组索引超出了整数的范围。是否有可能将long用作多数组的索引,或者您对如何存储这么大的数据集并仍然保持以适当的速度访问它有任何其他建议吗?谢谢! 最佳答案 officialdocumentation声明索引类型未指定,但查看repository,可以看到最有可能的定义是typedefstd::ptrdiff_tindex;因此,如果您为x8632位系统编译,无论如何您肯定会用完可寻址内存,因此索引大小的限制并不是您的真正

C++17 <functional> 模板参数推导不适用于 Xcode 10.1

我一直在尝试使用C++17(及更高版本)进行模板参数推导,并试图从cppreference.com编译这个确切的示例#includeintfunc(double){return0;}intmain(){std::functionf{func};//guide#1deducesfunctioninti=5;std::functiong=[&](double){returni;};//guide#2deducesfunction}它在该页面上的基于Web的编译器中编译并运行良好,但是当我尝试在我的MacbookPro上编译它时,它失败了,说error:noviableconstructor

c++ - 将 Boost 参数与 operator() 一起使用

我想将BoostParameter与重载调用运算符(operator())一起使用:#include#include#includestructadd_argument_tag{structname_;structdescr_;};staticinlineboost::parameter::keyword&name=boost::parameter::keyword::get();staticinlineboost::parameter::keyword&descr=boost::parameter::keyword::get();structconfig{BOOST_PARAMETE

c++ - Boost 1.69 中的某些库是否与 MacOS 不兼容?

我正在尝试编译一个程序,我在Ubuntu18.04和Windows10上编译时没有遇到任何问题。但是,当我尝试在OSXHighSierra上编译它时,出现错误,它们只与boost有关。这是一个例子:#include#includeintmain(){std::cout然后我尝试用g++和clang编译程序,如下所示:g++-std=c++11test.cpp-lpthread然后我得到了这个巨大的错误:Infileincludedfromtest.cpp:1:Infileincludedfrom/usr/local/include/boost/process.hpp:24:Infile

c++ - 错误 "lambda is not derived from ' std::function'

我正在尝试将lambda传递给通过可变参数模板定义的std::function,但似乎这在gcc上不起作用。有什么原因,为什么这段代码在gcc7.4.0上不起作用,但在VisualStudio2017上却能正常工作?有没有办法让它在gcc上也能工作,而无需先手动将其转换为std::function?#includetemplateintTestFunction(std::function){return0;}voidTest(){autofce=[](int/*n*/,double/*d*/){};//Thisdoesn'tworkwitherrornomatchingfunction

python - Cmake 找不到 boost_python

我正在尝试从thislink构建这个简单的boostpython演示在我的MacOSHighSierra上。以下是hello_ext.cpp:#includecharconst*greet(){return"hello,world";}BOOST_PYTHON_MODULE(hello_ext){usingnamespaceboost::python;def("greet",greet);}以下是CmakeLists.txt:cmake_minimum_required(VERSION3.5)#FindpythonandBoost-botharerequireddependencies

c++ - Boost Spirit 在 DLL 中使用时崩溃

我在使用Boost.Spirit和Boost.Thread时遇到崩溃我的应用程序中的库。这只有在我使用圣灵时才会发生在进程的生命周期内从主线程解析器。崩溃发生在退出时,似乎与清理由Spirit解析器分配的线程特定存储。它可能由于DLL的顺序而崩溃已卸载,因为线程特定内存是在DLL中分配的那已经被卸载了。然而,直到应用程序本身退出时,Boost.ThreadDLL才会被卸载。有没有办法让我强制Spirit清除它的特定线程存储,例如当我收到进程分离通知时在我的dll-main中?任何解决方案/提示将不胜感激。附言!我的平台和设置:VisualStudio2005BOOST_ALL_DYN_

c++ - boost::any_cast - 仅在隐式转换不可用时抛出?

我要boost::any_cast仅在any类型时抛出异常没有隐式转换为T.如果any的类型,正常行为似乎是抛出异常。不是T,不考虑隐式转换。例子:boost::anya=1;boost::any_cast(a);//Thissucceeds,andrightfullysoboost::any_cast(a);//Idon'twantthistothrowboost::any_cast(a);//Iwantthistothrow谁能告诉我是否有一种简单的方法来获得我想要的功能,或者更好的是给我一个充分的理由来说明为什么现有的行为是这样的? 最佳答案