c – “最重要的const”与auto_ptr:为什么代码不能编译?

以下代码无法在Visual C 2008和2010上编译:
#include <memory>

struct A {};

      std::auto_ptr<A> foo()  { return std::auto_ptr<A>(new A); }
const std::auto_ptr<A> bar()  { return std::auto_ptr<A>(new A); }

int main()
{
   const std::auto_ptr<A> & a = foo(); // most important const

   const std::auto_ptr<A> & b = bar(); // error C2558:
                                       // class 'std::auto_ptr<_Ty>' :
                                       // no copy constructor available or copy
                                       // constructor is declared 'explicit'

                                bar(); // No error?
}

我期望“最重要的const”应用于变量“b”,然而,它不会编译,并且由于某种原因,编译器要求复制构造函数(这让我感到惊讶,因为这里不应该涉及复制) .对bar()的独立调用工作正常,这意味着,我猜,实际上b的初始化是问题所在.

这是编译器错误,还是标准中描述的真正的编译错误

(也许它在C 98中被禁止并在C 11中被授权?)

注意:它在Visual C 2012,gcc 4.6和Solaris CC(所有编译器……)上编译,但不是gcc 3.4,也不是XL C)

解决方法

在C 03和C 98中,当将const引用绑定到rvalue(例如通过值返回的函数)时,实现可以将引用直接绑定到rvalue,或者它可以生成rvalue的副本并将引用绑定到该值.复制.由于auto_ptr的复制构造函数采用非const引用,因此第二种选择仅在返回的rvalue不是const限定的情况下才有效,但仍允许编译器尝试此操作,即使它不起作用.

在C 11中,不允许使用这些额外的副本,如果不需要转换,则实现必须直接绑定到rvalue.

See also here.

相关文章

本程序的编译和运行环境如下(如果有运行方面的问题欢迎在评...
水了一学期的院选修,万万没想到期末考试还有比较硬核的编程...
补充一下,先前文章末尾给出的下载链接的完整代码含有部分C&...
思路如标题所说采用模N取余法,难点是这个除法过程如何实现。...
本篇博客有更新!!!更新后效果图如下: 文章末尾的完整代码...
刚开始学习模块化程序设计时,估计大家都被形参和实参搞迷糊...