jjzjj

assignment

全部标签

c++ - std::vector::assign/std::vector::operator=(const&) 是否保证重用 `this` 中的缓冲区?

如果我将一个vector分配或复制到另一个vector(其容量与前者的大小相同或更大),我可以假设后者的缓冲区将被重用吗?下面的例子证明我可以,但是,标准保证吗?std::vector::assign和std::vector::operator=在这方面的行为有什么不同吗?#include#include#includeintmain(){std::vectora{1,2,3,4,5};std::vectorb{1,2,3,4};std::vectorc{1,2,3,4,5,6,7,8,9,10};std::coutLiveexample.更新:Thisanswer提到voidassi

c++ - is_assignable 和 std::unique_ptr

Here是来自gcc的测试文件,livedemostructdo_nothing{templatevoidoperator()(T*){}};intmain(){inti=0;std::unique_ptrp1(&i);std::unique_ptrp2;static_assert(!std::is_assignable::value,"");//note!here.}std::is_assignableIftheexpressionstd::declval()=std::declval()iswell-formedinunevaluatedcontext,providesthemem

c++ - 为什么 boost::assign::list_of 不适用于 pair<string, vector<string>>?

我不明白为什么这不起作用(VisualC++2012):#include#include#include#includeusingnamespacestd;intmain(){pair>("^",boost::assign::list_of("rules"));}错误是:include\utility(138):errorC2668:'std::vector::vector':ambiguouscalltooverloadedfunctionwith[_Ty=std::string]include\vector(786):couldbe'std::vector::vector(std:

c++ - STL - 赋值运算符与 `assign` 成员函数

vector(以及list和其他容器)有一个成员函数(MF)assign。我想比较assignMF(范围版本)与赋值运算符。据我所知,在以下情况下使用assign很有用:想要分配vector的子范围(不是从头到尾)。赋值是从一个数组完成的。在其他情况下,assignMF没有缺点,可以使用赋值运算符。我对吗?使用assignMF是否还有其他一些原因? 最佳答案 使用assign的主要原因就是将数据从一种容器复制到另一种容器。例如,如果您要迁移std::set的内容到std::vector,你不能使用赋值运算符,但你可以使用vector

c++ - 使用哪个 : move assignment operator vs copy assignment operator

我似乎不明白为什么要使用移动赋值运算符:CLASSA&operator=(CLASSA&&other);//moveassignmentoperator结束了,复制赋值运算符:CLASSA&operator=(CLASSAother);//copyassignmentoperator移动赋值运算符仅采用r值引用,例如CLASSAa1,a2,a3;a1=a2+a3;在复制赋值运算符中,other可以是使用复制构造函数或移动构造函数的构造函数(如果other是用右值初始化的,它可以是移动构造的——如果move-constructor定义了——)。如果它是copy-constructed,我

c++ - C/C++ 中的链式赋值是未定义的行为吗?

忽略变量的类型,像a=b=c这样的表达式是否在C和C++中都有定义的行为?如果是这样,谁能给我官方证据,比如标准中的引述,好吗?附言我搜索了链接赋值,但我得到的一切都是关联性,但我没有在C99标准中找到任何关于它的文本。也许我做错了?希望有人能帮助我。 最佳答案 来自C++标准5.17Assignmentandcompoundassignmentoperators[expr.ass]1Theassignmentoperator(=)andthecompoundassignmentoperatorsallgroupright-to-l

Object.assign详解

目录一、Object.assign是什么?二、用法:三、详细讲解1.目标对象和源对象没有同名属性2.目标对象和源对象有同名属性3.有多个源对象4、原始类型会被包装为对象5、对象的拷贝6、对象的深拷贝7、对象的深拷贝总结一、Object.assign是什么?object.assign()主要用于对象合并,将源对象中的属性复制到目标对象中,他将返回目标对象。二、用法:Object.assign(target,...sources)参数:target--->目标对象      source--->源对象返回值:target,目标对象三、详细讲解1.目标对象和源对象没有同名属性vartarget={n

c++ - 开关盒 : declaration-with-initialization & declaration-and-then-assignment

在switch-case语句中,declaration-with-initialization是无效的,但允许declaration-and-then-assignment。如以下代码片段所示。从编译器端看,这两种类型的初始化有什么区别?以及为什么第一种初始化无效而第二种初始化有效。switch(val){case0:intnewVal=42;//Invalidbreak;case1:intnewVal2;//ValidnewVal2=42;break;case2:break;} 最佳答案 实际上,规则是您不能跳入经过具有初始化的声

三种不同的控制 CRM UI Assignment Block 显示与否的技术

WebClientUI作为一种极佳的企业级应用UI开发技术,给开发人员提供了强大而灵活选择来实现用户的各种需求。在实际的CRM实施项目中,一个常见的要求是,概览页面中的某个分配块只能在某种情况下显示,例如被ABAPbusinessswitch开启与否的控制。本文以下是通过ABAP代码控制一个赋值块的可见性的三种方法。方法一:动态视图分离这种做法的思路是,redefine概述页面的控制器类的方法DETACH_STATIC_OVW_VIEWS.所有放入内部表rt_viewid中的视图将在运行时被UI框架隐藏。下面的代码是一个示意,开发人员可以评估第3行中的某些条件,如果满足条件,则赋值块Searc

c++ - 为什么assign前要有copy?

我正在做以下测试:#include#includeusingnamespacestd;classA{private:inti;public:A():i(1){cout输出是:AconstrAconstrAcopyAassigndestructAdestructAdestructA好像“o2=o1”是先复制后赋值,不知道这背后的故事是什么。谢谢! 最佳答案 因为您按值传递给赋值运算符:voidoperator=(constAa)您可能打算通过引用传递并且您还应该返回对分配给对象的引用:A&operator=(constA&a){std