草庐IT

boost_thread

全部标签

c++ - boost::可选抽象类类型

我想要一个抽象类型的可选对象。然而,boost::optional对于抽象类型是失败的:#includeclassA{virtualintgetInt()=0;};classB:publicA{intgetInt(){return666;};};intmain(){boost::optionalmaybeAnA;boost::optionalanother(maybeAnA);};结果error:invalidnew-expressionofabstractclasstype‘A’只使用指针似乎也不是一个可行的解决方案,因为某些函数需要返回一个包含可选值的对象作为成员,尽管期望函数的调

c++ - 将 boost::log::expressions::attr< std::string > 转换为 std::string

在使用Boost.Log时,我试图保留我的TimeStamp格式化程序,例如:logging::add_file_log(keywords::file_name="my.log",keywords::format=(expr::stream("TimeStamp","%Y-%m-%d%H:%M:%S")("Line")("File")据说我不能使用其他形式的格式化程序,因为我将很难转换"TimeStamp"转换成我的自定义格式:staticvoidmy_formatter(logging::record_viewconst&rec,logging::formatting_ostream

C++:具有 `std::lock_guard` 的互斥量是否足以同步两个 `std::thread`?

我的问题是基于下面的C++代码示例#include#include#include#includeclassClassUtility{public:ClassUtility(){}~ClassUtility(){}voiddo_something(){std::coutlock(g_mutex);std::coutlock(g_mutex);std::cout如果需要,这更像是一个问题,目的是让我的理解更清楚,并获取std::condition_variable的示例用法。我有2个C++std::thread,它们在main方法中启动。它是osx上的控制台应用程序。所以使用clang编

c++ - 如何将 `boost::static_visitor` 实例传递给函数

我正在使用boost::variant在我的项目中经常出现。我的同事们现在想出了传递特定boost::static_visitor实例的想法。以自定义访问类型。她有一些代码如下:#include#includetypedefboost::variantTVar;structVisitor1:publicboost::static_visitor{templateresult_typeoperator()(constT&){return42;}};structVisitor2:publicboost::static_visitor{templateresult_typeoperator(

c++ - Boost Variant 是否提供与 std 的 holds_alternative 类似的功能?

我在cppreference.com上找到了这段代码。我想知道boost是否为其变体类型提供了类似的功能。我发现boost文档真的很糟糕,找不到任何东西。intmain(){std::variantv="abc";std::cout(v)(v) 最佳答案 虽然不完全一样,但是可以使用基于指针的get函数:boost::variantv="abc";std::cout(&v)!=nullptr)(&v)!=nullptr) 关于c++-BoostVariant是否提供与std的holds_

c++ - Boost::signal 内存访问错误

我正在尝试使用boost::signal来实现回调机制,并且我在boost::signal代码中获得了内存访问断言,即使是对库的最微不足道的使用。我已将其简化为以下代码:#includetypedefboost::signalEvent;intmain(intargc,char*argv[]){Evente;return0;}谢谢!编辑:这是使用带有SP1的VisualStudio2008编译的Boost1.36.0。Boost::filesystem和boost::signal一样也有一个必须链接进去的库,看起来工作正常。我相信我使用的所有其他boost库都只有header。

c++ - 访问boost线程对象的成员变量

我正在使用一个对象来启动boost线程,它有一些我在线程中修改的公共(public)成员变量(在()运算符中)。如何从线程外部访问对象的成员变量?我尝试使用在对象的operator()中和从外部都被锁定的互斥锁(在对象的类中定义),但它似乎不起作用。线程对象代码如下:structMouse{intx,y;stringport;boost::mutexmutex;Mouse(conststring&p):port(p){x=y=0;}Mouse(constMouse&m):mutex(){x=m.x;y=m.y;port=m.port;}voidoperator()(){ifstream

c++ - Boost 图形库和访问者

我正在编写一个用于处理键合图的库,并且我正在使用BoostGraphLibrary为我存储数据。不幸的是,我似乎无法弄清楚如何使用它来实现适当的访问者模式,因为您不能子类化顶点-您必须依赖“属性”。库中提供的访问者框架似乎非常适合使用某些算法,其中顶点都是同一类型,但存储不同的信息。在我的问题中,顶点具有不同类型并存储不同类型的信息-一些顶点是电阻器,而一些是电容器等。我如何着手编写基于顶点属性而不是工作的访问者模式顶点本身?到目前为止,我唯一的想法是编写一个小类来表示指向我获取图形信息所需的原始顶点的对象的类型。然而,这看起来很笨拙,而且不好用。 最佳答案

C++ 用于 std 和 boost 命名空间的最佳实践

这个问题在这里已经有了答案:关闭12年前。PossibleDuplicate:Doyoupreferexplicitnamespacesor'using'inC++?我是一名C#开发人员,但我的friend是一名C++开发人员。他向我展示了充满调用的代码,例如std::for_each和boost::bind。我在C#中使用过,并认为使用指令会提高代码的可读性和通常更快的开发速度。例如,在C#foreach语句之前键入任何namespace会让人头疼。我想知道使用如此流行的命名空间有哪些利弊?包含这些命名空间是否是最佳实践?

c++ - boost 函数和 boost lambda

我已经看到了一些相关的问题,但我仍然感到困惑。这个语法有什么问题:boost::functiong=f;boost::functiong2=2*g(boost::lambda::_1);我已经在gcc4.3.4上使用boost1.35和1.38(这是我周围的两个安装)进行了尝试,它们都给出了错误的变体:nomatchforcallto'(boost::function)(constboost::lambda::lambda_functor>&)' 最佳答案 您不能直接调用带有占位符的函数。你必须usebind.boost::func