std::unique_ptr<int> ptr() {
std::unique_ptr<int> p(new int(3));
return p; // Why doesn't this require explicit move using std::move?
} // Why didn't the data pointed to by 'p' is not destroyed here though p is not moved?
int main() {
std::unique_ptr<int> a = ptr(); // Why doesn't this require std::move?
std::cout << *a; // Prints 3.
}
In the above code, the function ptr()
returns a copy of p
. When p
goes out of scope, the data '3' should get deleted. But how does the code work without any access violation?
std::unique_ptr<>
's move constructor. – Stanwin