草庐IT

boost-function

全部标签

c++ - boost::mpl::map 失败 boost::mpl::equal?

BoostMPL文档指出boost::map::equal"如果两个序列Seq1和Seq2比较_element__element_时是相同的。但似乎没有检查关联序列映射是否相等元素_wise_:下面的演示将展示这一点:Map2应该等于Map3,它们都递增“key”处的“int_”value_type。查看定义Map3的typedef。大小和唯一的元素被转储到演示中:#include#include#include#include#include#include#include#include#include#include#includenamespacempl=boost::mpl;

c++ - g++ 链接问题 : In function `_start' : (. text+0x20): undefined reference to `main'

我收到对主要错误的undefinedreference-即使我已经定义了主要,并且(AFAICT),我已经正确链接了它。这是我的代码和我使用的命令://################################################//proj1.h#ifndef__SCRATCH_PROJ1_H#define__SCRATCH_PROJ1_HintaddOne(inti);#endif/*__SCRATCH_PROJ1_H*///################################################//proj1.cpp#include"pr

c++ - boost::shared_mutex vs boost::mutex 用于多线程写入?

我有一个场景,其中多个线程正在写入一个公共(public)缓冲区(一个映射),每个线程可能有也可能没有相同的键。有人可以建议我是应该使用boost::shared_mutex还是只使用boost::mutex?我的理解是boost::shared_mutex适用于单个编写器和多个读取,这不是我想要的。这是否使boost::mutex更适合这种情况?提前致谢 最佳答案 是的,boost::shared_mutex不是您的情况,因为您没有纯读者并且有多个作者。只需使用boost::mutex强制对共享数据进行独占访问。

c++ - 如何将 boost::graph 算法与 listS、setS 作为顶点/边缘容器一起使用?

使用boost::graph库的boost示例通常使用像这样的图usingnamespaceboost;typedefadjacency_list,property>graph;因此它们工作得很好。但我有一个图表typedefadjacency_listgraph;并且算法不是开箱即用的。在大多数情况下,必须提供用于查找特定顶点索引(整数值)的vertex_descriptor的映射。我想检查我的图是否是平面图并计算它的平面嵌入。我提供了一个顶点索引图,它确实以这种方式工作,例如connected_components算法,但显然不适用于boyer_myrvold_planarity_

c++ - 使用 utf-32 解析器在 Boost.Spirit 中处理 utf-8

我有类似的问题Howtouseboost::spirittoparseUTF-8?和Howtomatchunicodecharacterswithboost::spirit?但这些都不能解决我面临的问题。我有一个带有UTF-8字符的std::string,我使用u8_to_u32_iterator包装std::string并使用unicode像这样的终端:BOOST_NETWORK_INLINEvoidparse_headers(std::stringconst&input,std::vector&container){usingnamespaceboost::spirit::qi;u

c++ - 是否可以在 [win-builder](http ://win-builder. r-project.org/) 上构建一个使用 Rcpp 和 Boost.Thread 的 R 包?

最近做了一个R包,用Rcpp把R和C++整合起来。而C++库Boost用于多线程。我想知道我的包是否可以构建在http://win-builder.r-project.org/上?我发现定义了一个Make变量---BOOSTLIB---,如图http://cran.r-project.org/bin/windows/contrib/ThirdPartySoftware.html.我尝试使用仅包含header的库,没问题,但是当我尝试使用单独编译的库Boost.Thread时,出现“没有这样的文件”或“undefinedreference”错误。也许lib路径是错误的。但是,我几乎找不到

c++ - Boost.Log 在每个日志语句后刷新

我对Boost.Log库有点陌生,第一印象真的很好,但有一件事已经花了很多时间,我无法解决。我想让Boost.Log立即将每条消息写入日志文件。我知道其他问题(I、II、III),但它们没有帮助。考虑这个example从boost文档中,下一个代码是相同的,只是我将auto_flush设置为true:namespacelogging=boost::log;namespacesrc=boost::log::sources;namespacesinks=boost::log::sinks;voidinit(){//Constructthesinktypedefsinks::synchron

c++ - 使用 -g 选项编译但 "Single stepping until exit from function main, which has no line number information"

我在使用gdb时遇到了一些问题。这是我在一个名为main.cpp的文件中的代码#includevoidmyfunc();intmain(){charmsg[]="HelloWorld!";myfunc();std::cout我使用这个命令来编译这段代码:g++-g-Wallmain.cpp-ofoo接下来,我使用了gdb:$gdbfoo(gdb)startTemporarybreakpoint1at0x80487c3Startingprogram:/home/laptop/workspace/fooTemporarybreakpoint1,0x080487c3inmain()(gdb)

c++ - 如何让 boost::serialization 工作?

我正在使用ubuntu12.04LTS并使用clang3.4。我有一个CMake项目,想使用boost序列化库。我从SourceForge下载了boost1.55.0。我的项目文件夹树如下所示:MyProject|Source||main.cpp||CMakeLists.txt|Build|Libraries||Boost1p55p0|||boost|||...otherboostdata|||build||||include||||lib所以在Boost1p55p0目录中,我创建了一个新目录build,这样Bootstrap看起来像:./bootstrap.sh--prefix=bu

c++ - std::function 在调用内部可变 lambda 时是否锁定互斥量?

除非另有说明,否则C++标准库对其类型提供以下保证:(1)读取操作(即处理const对象)是线程安全的。这意味着只要没有线程同时写入(应用非const操作)对象,多个线程就可以同时从对象读取而不会出现竞争条件。(2)多个线程可以同时读写任意对象,只要每个对象一次最多只能被一个线程访问。标准库需要用户类型的相同保证。(您可以在GotW#95中阅读这些内容或观看HerbatC++andBeyond2012对此的解释。)现在我的问题是,如果下面的结论是正确的:因为std::function的operator()是一个const成员函数,它需要是线程安全的。如果在构造时传入的仿函数有一个con