首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >引用引起的意外复制构造:我做错了什么?

引用引起的意外复制构造:我做错了什么?
EN

Stack Overflow用户
提问于 2011-10-25 05:38:04
回答 2查看 144关注 0票数 2

我有一些复杂的模板代码,其中调用OPC的复制构造函数,尽管我只是创建一个对OPC的引用(实际的实例是OP_S,它作为OPC的一个子类,不应该导致复制构造调用)。

我用gcc 4.6.1

代码在下面。

代码语言:javascript
复制
#include <stdio.h>

class OPC
{
    public:
        OPC() { }
        OPC( const OPC& f ) {
            fprintf( stderr, "CC called!!!\n" );
        }
};

template<class T>
class SL : public T
{ };

template<class T>
class S : public SL<T>
{ };

class OP_S : public S<OPC>
{ };

class TaskFoo
{
    public:
        TaskFoo( OPC& tf ) :
            m_opc(  tf ),
            m_copc( tf )
        { }
        OPC& getOPC() { return m_opc; }

    private:
        OPC&       m_opc;
        const OPC& m_copc;
};

int main(int argc, char** argv)
{
    OP_S op_s;
    TaskFoo tf( op_s );

    auto opc = tf.getOPC();  // this line results in a call to OPC's CC

    return 0;
}

回答,正如James McNellis在下面所指出的-需要auto&而不是auto

EN

回答 2

Stack Overflow用户

回答已采纳

发布于 2011-10-25 06:14:16

auto opc声明一个对象,而不是引用。就像你说过OPC opc一样。

如果希望opc成为引用,则需要auto& opc

票数 5
EN

Stack Overflow用户

发布于 2011-10-25 06:14:02

如果您想让opc作为参考,

代码语言:javascript
复制
auto &opc = tf.getOPC();

在C++11中,autoauto & (幸运地)有着不同的含义。因此,不管getOPC()返回一个引用,auto opc都会创建一个对象。

票数 4
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/7885104

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档