草庐IT

c++ - 不可复制和 move 构造函数

我已经使一个类的成员不可复制,但我给它一个move构造函数和赋值运算符。然而,它不会像vector一样与容器打球。classNonCopyable{public:NonCopyable(constNonCopyable&)=delete;NonCopyable&operator=(constNonCopyable&)=delete;protected:NonCopyable(){}~NonCopyable()_NOEXCEPT{}};classMember:NonCopyable{public:Member(inti):mNum(i){}~Member(){}Member(Member

c++ - 我怎么知道我使用的是复制还是 move ?

我对C++14标准库使用move语义的理解正确吗?换句话说,我可以确信我在以下程序中使用的是move而不是复制:#include#include#includeusingnamespacestd::string_literals;std::vectorgreeting(){std::vectorvs{"hello"s,"world"s};returnvs;}intmain(){std::vectors=greeting();std::cout有什么方法可以检查吗?在下面的例子中怎么样:#include#include#includeusingnamespacestd::string_l

c++ - 当从函数返回元组时,元组的参数被复制而不是 move

我对以下代码有疑问。我的编译器是MSVC++17VisualStudio15.3版,编译器选项为/std:c++14(相对于/std:c++latest),在Release模式下运行:structBar{inta;std::stringb;Bar(){std::coutfoo(){std::strings="dsdf";return{{1,s},{5,"asdf"}};}intmain(){Bara,b;std::tie(a,b)=foo();std::cout输出是:defaultdefaultdirectdirectmovebconstcopyconstcopymoveassign

c++ - 什么消息导致按钮发送 WM_COMMAND 消息

我知道单击Button时会向它的父级发送WM_COMMAND消息,但是它收到什么消息才能发送此消息?我正在覆盖按钮的默认WndProc,并且该按钮没有收到WM_COMMAND消息,因此我需要知道是什么消息导致按钮发送WM_COMMAND消息,以便我可以复制该功能。 最佳答案 我发现它实际上是WM_LBUTTONDOWN、WM_MOUSELEAVE和其他一些东西的组合。例如,WM_COMMAND只有在鼠标按下按钮时才会触发,并且在触发WM_LBUTTONUP时仍在按钮上。至于空格、输入等,我相信它只是处理VK_ENTER消息和其他东西

C++11 - 单独 move 数组(原始数组、std::array、std::vector)的每个元素?

在C++11中,move语义等等,人们可能想知道实际上可以move什么。这方面的一个例子是数组。是否可以move原始数组的每个元素,intarray1[8];intarray2[8];array1[0]=std::move(array2[0]);std::数组,std::arrayarray1;std::arrayarray2;array1[0]=std::move(array2[0]);和std::vectorsstd::vectorarray1;std::vectorarray2;array1[0]=std::move(array2[0]);个人? 最佳

c++ - 将从函数返回 vector<vector <int>> 调用 C++11 中的任何 move 构造函数

在C++11中将返回一个vector>从函数调用任何move构造函数?还是下面的代码只是制作所有vector及其元素的另一个拷贝?vector>Func(){vector>vec;//vecisfilledherereturnvec;}对于简单类型的STL容器,当使用move构造函数或将它们作为函数值返回时进行复制时,是否有一个通用的发现? 最佳答案 return语句在标准中特别涵盖,可自动视为move。所以是的,这将调用move构造函数。这方面的法律条文是C++11,[class.copy]§31+32:31Whencertain

c++ - 在继承的构造函数中仅 move 类参数

以下代码无法编译GCC6.1,但适用于Clang3.8.0和VisualStudio2015:#includeclassbase{public:base(std::unique_ptr){}};classderived:publicbase{public:usingbase::base;};intmain(){deriveddf(std::make_unique());}出现以下错误:main.cpp:Inconstructor'derived::derived(std::unique_ptr)':main.cpp:10:17:error:useofdeletedfunction'st

c++ - 为派生类 move 构造函数

我有2个类:templateclassbase{Tt;public:base(base&&b):t(std::move(b.t)){}};templateclassderived:protectedbase{T2t2;public:derived(derived&&d):base(std::move(d)),t2(std::move(d.t2)){}};我在derivedmove-constructor中move整个d对象来初始化base部分和d变得无效,但我仍然需要它来使用它作为t2初始化的一部分有可能做这样的事情吗? 最佳答案

c++ - std::string not nothrow move assignable or comparable?

我在研究type_traits时,发现了std::string的这个奇怪属性:$cata.cpp#include#includestatic_assert(std::is_nothrow_move_assignable::value,"???");static_assert(noexcept(std::declval()==std::declval()),"???");$g++-std=c++14a.cppa.cpp:4:1:error:staticassertionfailed:???static_assert(std::is_nothrow_move_assignable::val

c++ - 在此上下文中的完美转发和 std::move 行为

我是C++新手,我想了解完美转发如何与std::move结合使用.我定义了一个std::vectorqueue()我想使用模板函数填充fillWithData.由于我花了一些时间研究完美转发,所以我首先要检查我是否理解正确,其次要弄清楚move是什么。在此上下文中的行为。fillWithData是一个可变参数模板函数,感谢forward,能够通过折叠规则将参数视为左值或右值。(Q1-是否正确?)templatestaticvoidfillWithData(Container&oDataContainer,Args&&...args)//universalreference{typede