如果将匿名对象传递给需要引用的函数,C中会发生什么?
发布时间:2020-12-16 10:42:40 所属栏目:百科 来源:网络整理
导读:IE如果您有以下代码,会发生什么? int mean(const vectorint data) { int res = 0; for(size_t i = 0; i data.size(); i++) { res += data[i]; } return res/data.size();}vectorint makeRandomData() { vectorint stuff; int numInts = rand()%100; for(int
IE如果您有以下代码,会发生什么?
int mean(const vector<int> & data) { int res = 0; for(size_t i = 0; i< data.size(); i++) { res += data[i]; } return res/data.size(); } vector<int> makeRandomData() { vector<int> stuff; int numInts = rand()%100; for(int i = 0; i< numInts; i++) { stuff.push_back(rand()%100); } } void someRandomFunction() { int results = mean(makeRandomData()); } 我是否正确地认为C只会保留新创建的对象的生命,然后在它超出范围之后将其销毁? 此外,这如何工作/干扰RVO? 提前致谢. 编辑:添加const,忘了把它放进去. 解决方法
我的通灵能力告诉我你在Visual C上编译它,这就是为什么它甚至可以工作.在标准C中,你不能将rvalue(这是makeRandomData的返回值)传递给引用到非const,所以这个问题没有实际意义.
但是,如果您更改mean的签名以获取const向量< int>&,则该问题仍然有效.在这种情况下,它都归结为临时的生命周期 – 它被定义为持续到它出现的“完整表达式”结束.在您的特定情况下,完整表达式是结果的整个初始化程序.在表达式语句的情况下,完整表达式是整个语句. 标准没有指定函数参数可以抑制RVO的任何方式,但是,当然,RVO是编译器执行特定优化的任务,无论可见的副作用如何,都不需要这样做.何时(以及如果)RVO发生完全取决于您正在使用的特定编译器.也就是说,似乎没有任何理由可以以任何方式影响它. (编辑:李大同) 【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容! |
相关内容