Notice: This page requires JavaScript to function properly.
Please enable JavaScript in your browser settings or update your browser.
Lære Moving Unique Pointers | Unique Pointers
C++ Smart Pointers

book
Moving Unique Pointers

Copying Not Allowed

A std::unique_ptr is a smart pointer that manages a dynamically allocated object and ensures its proper deletion when it goes out of scope. It has exclusive ownership of the object it manages, meaning no two std::unique_ptr can own the same object simultaneously.

cpp

main

copy
#include <iostream>
#include <memory>

int main()
{
std::unique_ptr<int> first_unique_pointer = std::make_unique<int>(42);
// This will cause a compilation error: copying is not allowed
std::unique_ptr<int> second_unique_pointer = first_unique_pointer;
}
123456789
#include <iostream> #include <memory> int main() { std::unique_ptr<int> first_unique_pointer = std::make_unique<int>(42); // This will cause a compilation error: copying is not allowed std::unique_ptr<int> second_unique_pointer = first_unique_pointer; }

Moving a Unique Pointer

Although copying is not allowed, you can transfer ownership of the object using std::move. This moves the resource from one std::unique_ptr to another, leaving the original pointer empty.

cpp

main

copy
#include <iostream>
#include <memory>

int main()
{
std::unique_ptr<int> first_unique_pointer = std::make_unique<int>(42);
// Transferring ownership using std::move
std::unique_ptr<int> second_unique_pointer = std::move(first_unique_pointer);
if (!first_unique_pointer)
std::cout << "first_unique_pointer is now empty.\n";

std::cout << "second_unique_pointer owns the value: " << *second_unique_pointer << '\n';
}
123456789101112131415
#include <iostream> #include <memory> int main() { std::unique_ptr<int> first_unique_pointer = std::make_unique<int>(42); // Transferring ownership using std::move std::unique_ptr<int> second_unique_pointer = std::move(first_unique_pointer); if (!first_unique_pointer) std::cout << "first_unique_pointer is now empty.\n"; std::cout << "second_unique_pointer owns the value: " << *second_unique_pointer << '\n'; }

When you use std::move, ownership of the object is transferred from one unique pointer to another. After this, the original pointer no longer owns the object, and the new pointer becomes its owner.

Opgave

Swipe to start coding

Complete the following code in a way that the ownership of the dynamically allocated integer (with value 42) is safely transferred from unique_pointer_a to unique_pointer_b.

Løsning

cpp

solution

#include <iostream>
#include <memory>

int main()
{
// Creating a unique pointer here
std::unique_ptr<int> unique_pointer_a = std::make_unique<int>(42);
std::unique_ptr<int> unique_pointer_b = std::move(unique_pointer_a);

// Printing the contents of the unique pointer by dereferencing it
std::cout << (unique_pointer_b ? *unique_pointer_b : 0) << std::endl;
}
Var alt klart?

Hvordan kan vi forbedre det?

Tak for dine kommentarer!

Sektion 2. Kapitel 2
#include <iostream>
#include <memory>

int main()
{
// Creating a unique pointer here.
std::unique_ptr<int> unique_pointer_a = std::___<int>(42);
std::unique_ptr<int> unique_pointer_b = ___::___();

// Printing the contents of the unique pointer by dereferencing it.
std::cout << (unique_pointer_b ? *unique_pointer_b : 0) << std::endl;
}

Spørg AI

expand
ChatGPT

Spørg om hvad som helst eller prøv et af de foreslåede spørgsmål for at starte vores chat

We use cookies to make your experience better!
some-alt