2017-08-07 90 views
1

C++中有与智能指针相同的代码代码?相当于智能指标

在External.cpp:

class ExampleClass {...}; 

ExampleClass* function() 
{ 
    ExampleClass *ptr = new ExampleClass(); 
    ptr->doSomething(); 
    return ptr; 
} 

在Another.cpp我想这样做正确,?:

ExampleClass *ptr2 = function(); 
+3

看一看[这里](https://stackoverflow.com/questions/28294620/what-is-the-best-smart-pointer-return-type-for-a-factory-function)。您提供的代码似乎是工厂功能。 –

回答

5

有多么两个实际上,你可以使用任何的unique_ptr或shared_ptr的,看看这里时所使用的:Which kind of pointer do I use when?

I'f你选择的的unique_ptr,那么你会得到:

class ExampleClass {...}; 

std::unique_ptr<ExampleClass> function() 
{ 
    std::unique_ptr<ExampleClass> uptr = std::make_unique<ExampleClass>(); 
    uptr->doSomething(); 
    return std::move(uptr); 
} 

//In Another.cpp 
std::unique_ptr<ExampleClass> ptr2 = function(); 
//you could even store the result in a shared pointer!! 
std::shared_ptr<ExampleClass> ptr3 = function(); 
1

我不会真的推荐它,但你可以返回一个隐式转换为原始指针的对象。它将拥有它很短的时间,并删除如果没有人抓住它。

struct RelinquishOrDelete { 
    ExampleClass *_ptr; 

    operator ExampleClass*() { auto ret = _ptr; _ptr = nullptr; return ret; } 

    ~RelinquishOrDelete() { 
    if(!_ptr) { 
     cerr << "returned object wasn't taken by a new owner\n"; 
     delete _ptr; 
    } 
    } 
}; 

使用它很简单。这将打包和解包的指针在这个简单的例子:

RelinquishOrDelete function() 
{ 
    ExampleClass *ptr = new ExampleClass(); 
    ptr->doSomething(); 
    return {ptr}; 
} 

// ... 

ExampleClass *ptr2 = function(); 

不过,当然,如果在这个完全合理的一段代码中使用它可能会导致意外的行为:

auto ptr3 = function(); 

智能指针与更严格的所有权语义确实是最好的方法。