c – 返回的向量比通过引用传递的慢吗?
发布时间:2020-12-16 05:45:15 所属栏目:百科 来源:网络整理
导读:在过去,我们接受了培训,使用通过引用传递的结果参数,以避免不必要地复制数据. 然而,对于更聪明的编译器 – 特别是C 11的扩展是否还需要? 具体来说,是否有任何理由在2018年使用现代C 11 / C 14编译器(仍然) void Filter(vectorCObject* elements,vectorCObje
在过去,我们接受了培训,使用通过引用传递的结果参数,以避免不必要地复制数据.
然而,对于更聪明的编译器 – 特别是C 11的扩展是否还需要? 具体来说,是否有任何理由在2018年使用现代C 11 / C 14编译器(仍然) void Filter(vector<CObject*> &elements,vector<CObject*> &outElements); 而不是简单地返回矢量,即 vector<CObject*> Filter(vector<CObject*> &elements); 提前感谢您的所有见解! 解决方法
不会.在最好的情况下,RVO(返回值优化)将启动,这将完全忽略任何复制/移动. 在最坏的情况下,对象将被移出函数. std :: vector的移动非常便宜(仅与几个指针交换相比). 这是因为表达式Filter(some_input)是类型为std :: vector< CObject *>的rvalue,而std :: vector的构造函数具有接受rvalue引用的重载:see (6) here. (编辑:李大同) 【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容! |