草庐IT

boost-bimap

全部标签

c++ - SCons、Boost::ASIO、Windows 预编译 header 和链接器错误

在为多个平台开发C++时,我正在研究在构建过程中使用SCons。我在构建配置中完成了99%,但我在Windows上遇到了一个非常奇怪的错误,该错误与预编译头文件有关。更奇怪的是,它只发生在一个项目上。在这个项目的SConscript文件中,我有以下内容可以在Windows上编译PCH:ifenv['PLATFORM']=='win32':env['PCH']=env.PCH('MyPCH-LSCommon.pch','Common/src/MyPCH.h')[0]env['PCHSTOP']='"MyPCH.h"'我还设置了编译器标志以强制在项目中的所有文件中包含MyPCH.h:ife

c++ - 为什么 Boost 参数选择继承而不是组合?

我想这个网站上的大多数人都会同意可以通过两种方式外包实现:私有(private)继承作文继承最常被滥用。值得注意的是,当另一种形式或继承本来可以更好时,通常会使用公共(public)继承,并且通常应该使用组合而不是私有(private)继承。当然通常的注意事项适用,但我想不出任何时候我真的需要继承来解决实现问题。对于BoostParameterlibrary但是,您会注意到他们选择了继承而不是组合来实现命名参数习语(对于构造函数)。我只能想到经典的EBO(空基优化)解释,因为我看不到这里没有虚拟方法在起作用。有没有人知道更多或可以将我重定向到讨论?谢谢,马修。

c++ - Boost Test 寄存器异常翻译器

有人知道在Boost.Test中使用自动测试用例时如何注册我的自定义异常转换器吗?我找到了一些示例(实际上很少),但它们没有显示如何将此功能与自动测试用例一起使用,这在我看来是boost.test的最大优势。我的示例测试套件:#defineBOOST_TEST_MODULEStateMachineTest#defineBOOST_TEST_DYN_LINK#includeBOOST_AUTO_TEST_SUITE(FirstTest);BOOST_AUTO_TEST_CASE(testBasic){BOOST_CHECK(true);}BOOST_AUTO_TEST_SUITE_END

c++ - Boost.Program_options 固定数量的 token

Boost.Program_options提供了一种通过命令行参数传递多个标记的工具,如下所示:std::vectornums;po::options_descriptiondesc("Allowedoptions");desc.add_options()("help","Producehelpmessage.")("nums",po::value>(&nums)->multitoken(),"Numbers.");po::variables_mapvm;po::store(po::parse_command_line(argc,argv,desc),vm);po::notify(vm

c++ - Boost.Spirit.Lex :( 中 Phoenix 占位符 _val 出错

我是Boost.Spirit.Lex的新手。每次我尝试在我的简单词法分析器的语义操作中使用lex::_val时,都会出现一些奇怪的错误:#ifndef_TOKENS_H_#define_TOKENS_H_#include#include#include#include#include#includenamespacelex=boost::spirit::lex;namespacephx=boost::phoenix;enumtokenids{ID_IDENTIFICATOR=1,ID_CONSTANT,ID_OPERATION,ID_BRACKET,ID_WHITESPACES};te

c++ - 找出用于编译可执行文件/DLL 的 Boost 版本

有什么方法可以使用“字符串”或其他一些命令来决定使用哪个版本的Boost来编译特定的可执行文件或.so?我所拥有的只是可执行文件/.so本身。 最佳答案 Boost主要是一个只有头文件的库,广泛使用模板(所有模板都可能编译成一些优化的二进制文件)。仅给定可执行二进制文件,您很可能无法推断出所使用的Boost版本。可能是您了解使用哪个Boost版本的唯一方法是查看可执行文件的版本号(如果有的话),然后在它来自的源代码控制存储库中查找(如果您有权访问它)。 关于c++-找出用于编译可执行文件

c++ - 在生产者-消费者代码中使用 wait() boost 条件死锁

我已经使用Boost线程和条件实现了一个基本的线程生产者-消费者(线程1=生产者,线程2=消费者)。我经常无限期地陷入wait()中。我真的看不出这里有什么问题。下面是一些伪代码://mainclassclassMain{public:voidAddToQueue(...someData...){boost::mutex::scoped_locklock(m_mutex);m_queue.push_back(newQueueItem(...someData...));m_cond.notify_one();}voidRemoveQueuedItem(...someCond...){//

c++ - 我应该如何从 parent 的插槽中删除子对象?可能是 boost::asio 特定的

我编写了一个网络服务器类来维护一组std::网络客户端。网络客户端在断开连接时向网络服务器发出信号(通过boost::bind)。当网络客户端断开连接时,客户端实例需要从Set中移除并最终被删除。我认为这是一种常见的模式,但我遇到的问题可能是也可能不是ASIO特有的。我试图精简到只包含相关代码:/**NetworkServer.hpp**/classNetworkServices:privateboost::noncopyable{public:NetworkServices(void);~NetworkServices(void);private:voidrun();voidonNe

c++ - boost named_semaphore 示例?

我没能找到一个很好的例子来展示如何使用boost::interprocess::named_semaphore(甚至在Boost网站上也没有)。我可以看到一些关于interprocess_semaphore的东西,但它们似乎完全不同,我不知道为一个显示的内容是否也适用于另一个。任何人都可以给我一些指向此类示例/tutorials/documentation的链接吗?谢谢。 最佳答案 interprocess_semaphore和named_semaphore之间的主要区别在于interprocess_semaphore是通过使用共享

c++ - 在 boost::test::unit_test 中查找内存泄漏

这个问题是continuationtoapreviousquestion在boost::test::unit_test上。我已经编写了单元测试并构建了单元测试。这是构建输出:2>------Buildstarted:Project:UnitTests,Configuration:DebugWin32------2>stdafx.cpp2>UnitTests.cpp2>UnitTests.vcxproj->F:\Src\Crash\trunk\Debug\UnitTests.exe2>2>Running3testcases...2>Testsuite"MasterTestSuite"pa