Я видел следующий код,
#include <new>
#include <memory>
using namespace std;
class Fred; // Forward declaration
typedef auto_ptr<Fred> FredPtr;
class Fred {
public:
static FredPtr create(int i)
{
return new Fred(i); // Is there an implicit casting here? If not, how can we return
// a Fred* with return value as FredPtr?
}
private:
Fred(int i=10) : i_(i) { }
Fred(const Fred& x) : i_(x.i_) { }
int i_;
};
Пожалуйста, посмотрите вопрос, указанный в функции create.
Спасибо
// Обновлено на основе комментариев
Да, код не может передать ошибку VC8.0 C2664: 'std :: auto_ptr <_Ty> :: auto_ptr (std :: auto_ptr <_Ty> &) throw ()': невозможно преобразовать параметр 1 из 'Fred *'to' std :: auto_ptr <_Ty> & '
Код был скопирован из C ++ FAQ 12.15.
Однако, после внесения следующих изменений,
replace
return new Fred(i);
with
return auto_ptr<Fred>(new Fred(i));
Этот код может пройти компилятор VC8.0.Но я не уверен, является ли это правильным исправлением.