Учитывая приведенный ниже код, в чем разница между unique_ptr и Bar, которые сделали bar ( { new int } );
хорошо но не foo( { new int } );
#include <memory>
struct Bar {
Bar() = default;
Bar( int* m ) : m_( m ) {};
~Bar() { if ( m_ ) delete m_; }
explicit operator bool() const { return m_; }
private:
int* m_ {};
};
bool bar( Bar && a ) { return bool(a); }
bool foo( std::unique_ptr<int> && a) { return bool(a); }
int main() {
bar( { } ); // ok
bar( Bar{ new int } ); // ok
bar( { new int } ); // ok
foo( { } ); // ok
foo( std::unique_ptr<int>{ new int } ); // ok
foo( { new int } ); // compile error
}
Ошибка компиляции с clang 3.5:
+ clang++ -std=c++1y -O3 -W -Wall -Wextra -pedantic -pthread main.cpp
main.cpp:22:5: error: no matching function for call to 'foo'
foo( { new int } ); // compile error
^~~
main.cpp:13:6: note: candidate function not viable: cannot convert initializer list argument to 'std::unique_ptr<int>'
bool foo( std::unique_ptr<int> && a) { return bool(a); }
Конструктор указателя с одним аргументом unique_ptr
является explicit
:
explicit unique_ptr( pointer p );
Других решений пока нет …