草庐IT

pybind11

全部标签

c++ - 如何在标准 C++11 中创建 shared_lock 或 upgrade_lock?

新标准std::shared_lock我非常想念模板类。在Boost.Thread中有boost::shared_lock,甚至boost::upgrade_lock存在。为什么,没有std::shared_lock和std::unique_lock在C++11中?如何获得与boost::shared_lock类似的行为?有,但在纯C++11中?我正在考虑使用boost::shared_lock,但这没有多大意义,因为std::mutex没有lock_shared()成员。而且,没有诸如std::shared_mutex之类的。. 最佳答案

c++ - 切换到C++11时,是否需要重新编译接口(interface)中使用STL的所有依赖库?

我正在尝试将一个大型项目切换为使用C++11。我遇到了大量链接器错误,这些错误似乎是由使用C++11编译的库和使用C++03编译的库之间的STL类上不匹配的命名空间引起的。例如,假设库B是A的依赖项。B具有以下模板化类作为其接口(interface)的一部分。templateclassVectorParameter{public:VectorParameter();virtual~VectorParameter();...}库A使用VectorParameter>实例化模板.当我用C++11重新编译A而没有重新编译B时,我遇到了链接器错误并提示LFE::VectorParameter>

c++ - 在单行中通过 XOR 交换整数。在 C++11 中真的允许吗?

我仍然无法清楚地理解表达式x^=y^=x^=y;在C++11中有效(正如他们在thread中所说)还是会导致未定义的行为?链接给出的理由似乎很有说服力,但clang抛出一个warning:warning:unsequencedmodificationandaccessto'x'[-Wunsequenced]此外,如果两个版本:x^=y^=x^=y;//(1)x=x^(y=y^(x=(x^y)));//(2)被认为是等效的(并且在C++11中定义明确),为什么它会给出不同的结果(first,second)?此外,应该注意gcc给出了一个warning仅在第二版代码上关于序列点。

c++ - 如何使用 C++11 正确初始化 'struct stat'?

多年来,我一直像这样初始化我的structstat:#includestructstatfoo={0};具体来说,{0}将所有字段设置为零,相当于memset(&foo,NULL,sizeoffoo);。现在使用C++11,这已经开始产生警告:foo.cpp:2:19:warning:missingfield'st_mode'initializer[-Wmissing-field-initializers]structstats={0};^这是因为C++11的新初始化语法,警告暗示我没有初始化所有成员。在C++11中实例化和初始化structstat的首选方法是什么?

c++ - 如何使用 C++11 std::bind 绑定(bind)类中同名的成员函数之一

classTest{public:intwork(){coutf=std::bind(&Test::work,&test);threadth(f);th.join();return0;}如上代码,我想绑定(bind)一个类的成员函数voidwork(void)(暂且命名为Test),但是出现编译器错误提示无法确定使用哪个重写函数。我无法更改类Test,因为它属于一个库,如何实现我的目标?提前致谢! 最佳答案 为什么不完全跳过std::bind而使用lambda?autofp=[&t](){t.test()};作为奖励,您的可执行文件

c++ - 我们什么时候应该使用圆括号 ( ) 与 initializer { } 语法来初始化 C++11 中的对象?

这个问题在这里已经有了答案:Whentousethebrace-enclosedinitializer?(3个答案)关闭6年前。已更新我已经通过链接(例如Whentousethebrace-enclosedinitializer?)了解何时应该使用{}大括号初始化,但没有给出何时应该使用括号()的信息与初始值设定项{}在C++11/14中初始化对象的语法?建议使用哪些标准做法()在{}?在极少数情况下,例如vectorv(10,20);或autov=vector(10,20);,结果是std::vector有10个元素。如果我们使用大括号,结果是std::vector有2个元素。但这取

C++11:memory_order_relaxed 和 memory_order_consume 的区别

我现在正在学习C++11memoryordermodel并想了解memory_order_relaxed和memory_order_consume之间的区别。具体来说,我正在寻找一个无法将memory_order_consume替换为memory_order_relaxed的简单示例。有一个优秀的post它详细阐述了一个简单但非常具有说明性的示例,其中可以应用memory_order_consume。以下是文字复制粘贴。例子:atomicGuard(nullptr);intPayload=0;制作人:Payload=42;Guard.store(&Payload,memory_orde

c++ - Qt 5.7 将 -std=gnu++11 添加到我的编译器标志,破坏 -std=c++14

我在我的CMakeLists.txt中设置了以下标志set(CMAKE_CXX_FLAGS"-std=c++14-g-O0")然后我使用find_package找到Qt5Testfind_package(Qt5TestREQUIRED)然后我正在创建一个ModelTest图书馆add_library(modeltestSTATIC${SRCS})target_link_libraries(modeltestQt5::Test)出于某种原因,我将-fPIC-std=gnu++11添加到我的编译器标志中CMakeFiles/modeltest.dir/flags.make:CXX_FLAG

c++ - 在 C++ 11 中将指针传递给临时变量?

我有一个现有的功能:voidfoo(constKey*key=nullptr){//usesthekey}我想将它的指针传递给临时Key对象(即右值),例如:foo(&Key());这会导致编译错误,但在C++11/14中有什么方法可以做到这一点吗?我当然可以:Keykey;foo(&key);但是我不需要objectKey,我只需要在foo()和foo()里面或者我可以这样做:foo(newKey());但是对象不会被删除。 最佳答案 我不认为这是个好主意,但如果你真的想要一个临时文件并且不能更改foo,你可以将临时文件转换为co

C++11 Lambda 表达式作为回调函数

是否有任何C++GUI工具包支持将回调函数定义为C++11lambda表达式?我相信这是使用C#(至少与C++相比)编写基于GUI的程序的独特优势。对于将lambda表达式作为参数的函数,我应该使用什么类型签名?这些函数如何支持隐式转换? 最佳答案 问题第二部分的答案:您可以使用std::function其中Signature=例如void(int)或者-如果lambda不采用闭包-旧的void(Foo*)(int)方法,因为没有闭包的lambda必须可以转换为正确的函数类型。因此,例如调用带有签名的方法:voidAddHandle