Why am I allowed to create multiple unique pointers from a single object? The Next CEO of Stack OverflowWhy use pointers?Pretty-print C++ STL containersC++ pointers local in functionsHow C++ reference worksWhy is reading lines from stdin much slower in C++ than Python?Why should I use a pointer rather than the object itself?Pointers as Function Parameters ExampleReturn class object pointer from another classwhy should we use std::move semantic with unique pointers?Why does my object appear to be on the heap without using `new`?

How to set page number in right side in chapter title page?

Can someone explain this formula for calculating Manhattan distance?

How do I fit a non linear curve?

What is the difference between "hamstring tendon" and "common hamstring tendon"?

"Eavesdropping" vs "Listen in on"

Is it correct to say moon starry nights?

Is there such a thing as a proper verb, like a proper noun?

Would a completely good Muggle be able to use a wand?

Why don't programming languages automatically manage the synchronous/asynchronous problem?

Why is the US ranked as #45 in Press Freedom ratings, despite its extremely permissive free speech laws?

IC has pull-down resistors on SMBus lines?

Won the lottery - how do I keep the money?

Is there an equivalent of cd - for cp or mv

Reference request: Grassmannian and Plucker coordinates in type B, C, D

Help/tips for a first time writer?

Graph of the history of databases

0-rank tensor vs vector in 1D

What day is it again?

What steps are necessary to read a Modern SSD in Medieval Europe?

What was Carter Burke's job for "the company" in Aliens?

Do I need to write [sic] when including a quotation with a number less than 10 that isn't written out?

Players Circumventing the limitations of Wish

Why the last AS PATH item always is `I` or `?`?

Small nick on power cord from an electric alarm clock, and copper wiring exposed but intact



Why am I allowed to create multiple unique pointers from a single object?



The Next CEO of Stack OverflowWhy use pointers?Pretty-print C++ STL containersC++ pointers local in functionsHow C++ reference worksWhy is reading lines from stdin much slower in C++ than Python?Why should I use a pointer rather than the object itself?Pointers as Function Parameters ExampleReturn class object pointer from another classwhy should we use std::move semantic with unique pointers?Why does my object appear to be on the heap without using `new`?










13















Why am I allowed to create multiple unique pointers from a single object?



#include <iostream>
#include <memory>

using namespace std;

class Class

public:
Class(int a): int_(a)std::cout << "constr" << std::endl;
~Class()std::cout << "destr" << std::endl;
int int_;

;

int main()

Class a(4);
std::unique_ptr<Class> ptr = std::make_unique<Class>(a);
std::unique_ptr<Class> ptr2 = std::make_unique<Class>(a);
std::unique_ptr<Class> ptr3 = std::make_unique<Class>(a);
std::cout << ptr->int_ << std::endl;
std::cout << ptr2->int_ << std::endl;
std::cout << ptr3->int_ << std::endl;

return 0;



Output:



constr
4
4
4
destr
destr
destr
destr









share|improve this question









New contributor




Lokas Beard is a new contributor to this site. Take care in asking for clarification, commenting, and answering.
Check out our Code of Conduct.















  • 21





    Copy construction.

    – user4581301
    2 days ago






  • 1





    Try this: a.int_ = 5; after you create each unique_ptr and before you print the contents of each pointer

    – alter igel
    2 days ago






  • 1





    Creating several unique_ptr to the same instance will almost certainly lead to undefined behavior, but that's not what you are doing here. Something like auto ptr2 = std::unique_ptr<Class>(ptr.get()); would create a second std::unique_ptr that points to the same instance as ptr does, and that would be problematic.

    – François Andrieux
    2 days ago











  • Demo with user-defined copy constructor (called 3 times). Exemplifies the underlying copy construction.

    – TrebledJ
    yesterday















13















Why am I allowed to create multiple unique pointers from a single object?



#include <iostream>
#include <memory>

using namespace std;

class Class

public:
Class(int a): int_(a)std::cout << "constr" << std::endl;
~Class()std::cout << "destr" << std::endl;
int int_;

;

int main()

Class a(4);
std::unique_ptr<Class> ptr = std::make_unique<Class>(a);
std::unique_ptr<Class> ptr2 = std::make_unique<Class>(a);
std::unique_ptr<Class> ptr3 = std::make_unique<Class>(a);
std::cout << ptr->int_ << std::endl;
std::cout << ptr2->int_ << std::endl;
std::cout << ptr3->int_ << std::endl;

return 0;



Output:



constr
4
4
4
destr
destr
destr
destr









share|improve this question









New contributor




Lokas Beard is a new contributor to this site. Take care in asking for clarification, commenting, and answering.
Check out our Code of Conduct.















  • 21





    Copy construction.

    – user4581301
    2 days ago






  • 1





    Try this: a.int_ = 5; after you create each unique_ptr and before you print the contents of each pointer

    – alter igel
    2 days ago






  • 1





    Creating several unique_ptr to the same instance will almost certainly lead to undefined behavior, but that's not what you are doing here. Something like auto ptr2 = std::unique_ptr<Class>(ptr.get()); would create a second std::unique_ptr that points to the same instance as ptr does, and that would be problematic.

    – François Andrieux
    2 days ago











  • Demo with user-defined copy constructor (called 3 times). Exemplifies the underlying copy construction.

    – TrebledJ
    yesterday













13












13








13


2






Why am I allowed to create multiple unique pointers from a single object?



#include <iostream>
#include <memory>

using namespace std;

class Class

public:
Class(int a): int_(a)std::cout << "constr" << std::endl;
~Class()std::cout << "destr" << std::endl;
int int_;

;

int main()

Class a(4);
std::unique_ptr<Class> ptr = std::make_unique<Class>(a);
std::unique_ptr<Class> ptr2 = std::make_unique<Class>(a);
std::unique_ptr<Class> ptr3 = std::make_unique<Class>(a);
std::cout << ptr->int_ << std::endl;
std::cout << ptr2->int_ << std::endl;
std::cout << ptr3->int_ << std::endl;

return 0;



Output:



constr
4
4
4
destr
destr
destr
destr









share|improve this question









New contributor




Lokas Beard is a new contributor to this site. Take care in asking for clarification, commenting, and answering.
Check out our Code of Conduct.












Why am I allowed to create multiple unique pointers from a single object?



#include <iostream>
#include <memory>

using namespace std;

class Class

public:
Class(int a): int_(a)std::cout << "constr" << std::endl;
~Class()std::cout << "destr" << std::endl;
int int_;

;

int main()

Class a(4);
std::unique_ptr<Class> ptr = std::make_unique<Class>(a);
std::unique_ptr<Class> ptr2 = std::make_unique<Class>(a);
std::unique_ptr<Class> ptr3 = std::make_unique<Class>(a);
std::cout << ptr->int_ << std::endl;
std::cout << ptr2->int_ << std::endl;
std::cout << ptr3->int_ << std::endl;

return 0;



Output:



constr
4
4
4
destr
destr
destr
destr






c++ pointers unique-ptr






share|improve this question









New contributor




Lokas Beard is a new contributor to this site. Take care in asking for clarification, commenting, and answering.
Check out our Code of Conduct.











share|improve this question









New contributor




Lokas Beard is a new contributor to this site. Take care in asking for clarification, commenting, and answering.
Check out our Code of Conduct.









share|improve this question




share|improve this question








edited yesterday









TrebledJ

3,46911228




3,46911228






New contributor




Lokas Beard is a new contributor to this site. Take care in asking for clarification, commenting, and answering.
Check out our Code of Conduct.









asked 2 days ago









Lokas BeardLokas Beard

715




715




New contributor




Lokas Beard is a new contributor to this site. Take care in asking for clarification, commenting, and answering.
Check out our Code of Conduct.





New contributor





Lokas Beard is a new contributor to this site. Take care in asking for clarification, commenting, and answering.
Check out our Code of Conduct.






Lokas Beard is a new contributor to this site. Take care in asking for clarification, commenting, and answering.
Check out our Code of Conduct.







  • 21





    Copy construction.

    – user4581301
    2 days ago






  • 1





    Try this: a.int_ = 5; after you create each unique_ptr and before you print the contents of each pointer

    – alter igel
    2 days ago






  • 1





    Creating several unique_ptr to the same instance will almost certainly lead to undefined behavior, but that's not what you are doing here. Something like auto ptr2 = std::unique_ptr<Class>(ptr.get()); would create a second std::unique_ptr that points to the same instance as ptr does, and that would be problematic.

    – François Andrieux
    2 days ago











  • Demo with user-defined copy constructor (called 3 times). Exemplifies the underlying copy construction.

    – TrebledJ
    yesterday












  • 21





    Copy construction.

    – user4581301
    2 days ago






  • 1





    Try this: a.int_ = 5; after you create each unique_ptr and before you print the contents of each pointer

    – alter igel
    2 days ago






  • 1





    Creating several unique_ptr to the same instance will almost certainly lead to undefined behavior, but that's not what you are doing here. Something like auto ptr2 = std::unique_ptr<Class>(ptr.get()); would create a second std::unique_ptr that points to the same instance as ptr does, and that would be problematic.

    – François Andrieux
    2 days ago











  • Demo with user-defined copy constructor (called 3 times). Exemplifies the underlying copy construction.

    – TrebledJ
    yesterday







21




21





Copy construction.

– user4581301
2 days ago





Copy construction.

– user4581301
2 days ago




1




1





Try this: a.int_ = 5; after you create each unique_ptr and before you print the contents of each pointer

– alter igel
2 days ago





Try this: a.int_ = 5; after you create each unique_ptr and before you print the contents of each pointer

– alter igel
2 days ago




1




1





Creating several unique_ptr to the same instance will almost certainly lead to undefined behavior, but that's not what you are doing here. Something like auto ptr2 = std::unique_ptr<Class>(ptr.get()); would create a second std::unique_ptr that points to the same instance as ptr does, and that would be problematic.

– François Andrieux
2 days ago





Creating several unique_ptr to the same instance will almost certainly lead to undefined behavior, but that's not what you are doing here. Something like auto ptr2 = std::unique_ptr<Class>(ptr.get()); would create a second std::unique_ptr that points to the same instance as ptr does, and that would be problematic.

– François Andrieux
2 days ago













Demo with user-defined copy constructor (called 3 times). Exemplifies the underlying copy construction.

– TrebledJ
yesterday





Demo with user-defined copy constructor (called 3 times). Exemplifies the underlying copy construction.

– TrebledJ
yesterday












3 Answers
3






active

oldest

votes


















36














Why not?



You are not creating multiple unique_ptr instances pointing to the same Class instance, but you are instead allocating three new Class instances on the heap, copy-constructed from a. Every unique_ptr points to a different instance.




std::unique_ptr<Class> ptr = std::make_unique<Class>(a);


The above means: create a new instance of Class on the heap, copy-constructed from a, and give ownership of it to a new std::unique_ptr instance with name ptr.






share|improve this answer























  • What i don't understand is he didn't provide a copy constructor. I know that if you don't create a custom constructor, the compiler will generate for you default, copy, move, etc. But, in this case, he provided a custom constructor.

    – Jordan Motta
    2 days ago






  • 11





    @JordanMotta: adding a non-default constructor does not inhibit implicit generation of the copy constructor. See i.stack.imgur.com/b2VBV.png

    – Vittorio Romeo
    2 days ago



















20















Why am I allowed to create multiple unique pointers from a single object?




You're not allowed to do that*, so it's a good thing you're not doing that!



Don't forget, this:



std::unique_ptr<Class> ptr = std::make_unique<Class>(a);


is this**:



std::unique_ptr<Class> ptr(new Class(a));


not this:



std::unique_ptr<Class> ptr(&a);


std::make_unique creates a thing and gives you a unique_ptr to that thing. It does so by forwarding its arguments to the thing's constructor. Admittedly this can be confusing when you pass in the name of an existing object, leading to the copy constructor being used.



tl;dr: You're creating copies of a.



* Well, with a no-op deleter you could do it safely, but let's save that conversation for another day…
** More or less…






share|improve this answer




















  • 1





    you can prove this to yourself by ptr2->_int = 6; and then 7 and so on. You will see that changing the Class one pointer points to has no effect on the others. They are just a bunch of copies.

    – Kate Gregory
    2 days ago











  • Cunning of you to place the TD;DR version at the bottom of the answer, guaranteeing that most people will read the the full version first. Another simple proof is to remove the copy constructor (Class(const Class &) =delete;) the copy constructor and watch the compiler choke.

    – user4581301
    2 days ago






  • 1





    @user4581301 Conclusions and summaries have been used for centuries. Feel free to write your own answer.

    – Lightness Races in Orbit
    yesterday


















10















Why am I allowed to create multiple unique pointers from a single object?




You're allowed to make multiple copies of the object, because the class is copyable.




"Unique" in unique_ptr doesn't mean that the pointed object is the unique instance of its class. It means that no other pointer should have ownership of the pointed object. In your example, each unique pointer points to a separate instance; each of the uniquely owned by the respective pointer.



You could violate the uniqueness like this:



std::unique_ptr<Class> ptr(&a);


Could: The program would be well-formed and compiler would be required to compile it. But the behaviour of the program would then be undefined, so you very much should not do that.






share|improve this answer

























    Your Answer






    StackExchange.ifUsing("editor", function ()
    StackExchange.using("externalEditor", function ()
    StackExchange.using("snippets", function ()
    StackExchange.snippets.init();
    );
    );
    , "code-snippets");

    StackExchange.ready(function()
    var channelOptions =
    tags: "".split(" "),
    id: "1"
    ;
    initTagRenderer("".split(" "), "".split(" "), channelOptions);

    StackExchange.using("externalEditor", function()
    // Have to fire editor after snippets, if snippets enabled
    if (StackExchange.settings.snippets.snippetsEnabled)
    StackExchange.using("snippets", function()
    createEditor();
    );

    else
    createEditor();

    );

    function createEditor()
    StackExchange.prepareEditor(
    heartbeatType: 'answer',
    autoActivateHeartbeat: false,
    convertImagesToLinks: true,
    noModals: true,
    showLowRepImageUploadWarning: true,
    reputationToPostImages: 10,
    bindNavPrevention: true,
    postfix: "",
    imageUploader:
    brandingHtml: "Powered by u003ca class="icon-imgur-white" href="https://imgur.com/"u003eu003c/au003e",
    contentPolicyHtml: "User contributions licensed under u003ca href="https://creativecommons.org/licenses/by-sa/3.0/"u003ecc by-sa 3.0 with attribution requiredu003c/au003e u003ca href="https://stackoverflow.com/legal/content-policy"u003e(content policy)u003c/au003e",
    allowUrls: true
    ,
    onDemand: true,
    discardSelector: ".discard-answer"
    ,immediatelyShowMarkdownHelp:true
    );



    );






    Lokas Beard is a new contributor. Be nice, and check out our Code of Conduct.









    draft saved

    draft discarded


















    StackExchange.ready(
    function ()
    StackExchange.openid.initPostLogin('.new-post-login', 'https%3a%2f%2fstackoverflow.com%2fquestions%2f55420227%2fwhy-am-i-allowed-to-create-multiple-unique-pointers-from-a-single-object%23new-answer', 'question_page');

    );

    Post as a guest















    Required, but never shown

























    3 Answers
    3






    active

    oldest

    votes








    3 Answers
    3






    active

    oldest

    votes









    active

    oldest

    votes






    active

    oldest

    votes









    36














    Why not?



    You are not creating multiple unique_ptr instances pointing to the same Class instance, but you are instead allocating three new Class instances on the heap, copy-constructed from a. Every unique_ptr points to a different instance.




    std::unique_ptr<Class> ptr = std::make_unique<Class>(a);


    The above means: create a new instance of Class on the heap, copy-constructed from a, and give ownership of it to a new std::unique_ptr instance with name ptr.






    share|improve this answer























    • What i don't understand is he didn't provide a copy constructor. I know that if you don't create a custom constructor, the compiler will generate for you default, copy, move, etc. But, in this case, he provided a custom constructor.

      – Jordan Motta
      2 days ago






    • 11





      @JordanMotta: adding a non-default constructor does not inhibit implicit generation of the copy constructor. See i.stack.imgur.com/b2VBV.png

      – Vittorio Romeo
      2 days ago
















    36














    Why not?



    You are not creating multiple unique_ptr instances pointing to the same Class instance, but you are instead allocating three new Class instances on the heap, copy-constructed from a. Every unique_ptr points to a different instance.




    std::unique_ptr<Class> ptr = std::make_unique<Class>(a);


    The above means: create a new instance of Class on the heap, copy-constructed from a, and give ownership of it to a new std::unique_ptr instance with name ptr.






    share|improve this answer























    • What i don't understand is he didn't provide a copy constructor. I know that if you don't create a custom constructor, the compiler will generate for you default, copy, move, etc. But, in this case, he provided a custom constructor.

      – Jordan Motta
      2 days ago






    • 11





      @JordanMotta: adding a non-default constructor does not inhibit implicit generation of the copy constructor. See i.stack.imgur.com/b2VBV.png

      – Vittorio Romeo
      2 days ago














    36












    36








    36







    Why not?



    You are not creating multiple unique_ptr instances pointing to the same Class instance, but you are instead allocating three new Class instances on the heap, copy-constructed from a. Every unique_ptr points to a different instance.




    std::unique_ptr<Class> ptr = std::make_unique<Class>(a);


    The above means: create a new instance of Class on the heap, copy-constructed from a, and give ownership of it to a new std::unique_ptr instance with name ptr.






    share|improve this answer













    Why not?



    You are not creating multiple unique_ptr instances pointing to the same Class instance, but you are instead allocating three new Class instances on the heap, copy-constructed from a. Every unique_ptr points to a different instance.




    std::unique_ptr<Class> ptr = std::make_unique<Class>(a);


    The above means: create a new instance of Class on the heap, copy-constructed from a, and give ownership of it to a new std::unique_ptr instance with name ptr.







    share|improve this answer












    share|improve this answer



    share|improve this answer










    answered 2 days ago









    Vittorio RomeoVittorio Romeo

    59.4k17163307




    59.4k17163307












    • What i don't understand is he didn't provide a copy constructor. I know that if you don't create a custom constructor, the compiler will generate for you default, copy, move, etc. But, in this case, he provided a custom constructor.

      – Jordan Motta
      2 days ago






    • 11





      @JordanMotta: adding a non-default constructor does not inhibit implicit generation of the copy constructor. See i.stack.imgur.com/b2VBV.png

      – Vittorio Romeo
      2 days ago


















    • What i don't understand is he didn't provide a copy constructor. I know that if you don't create a custom constructor, the compiler will generate for you default, copy, move, etc. But, in this case, he provided a custom constructor.

      – Jordan Motta
      2 days ago






    • 11





      @JordanMotta: adding a non-default constructor does not inhibit implicit generation of the copy constructor. See i.stack.imgur.com/b2VBV.png

      – Vittorio Romeo
      2 days ago

















    What i don't understand is he didn't provide a copy constructor. I know that if you don't create a custom constructor, the compiler will generate for you default, copy, move, etc. But, in this case, he provided a custom constructor.

    – Jordan Motta
    2 days ago





    What i don't understand is he didn't provide a copy constructor. I know that if you don't create a custom constructor, the compiler will generate for you default, copy, move, etc. But, in this case, he provided a custom constructor.

    – Jordan Motta
    2 days ago




    11




    11





    @JordanMotta: adding a non-default constructor does not inhibit implicit generation of the copy constructor. See i.stack.imgur.com/b2VBV.png

    – Vittorio Romeo
    2 days ago






    @JordanMotta: adding a non-default constructor does not inhibit implicit generation of the copy constructor. See i.stack.imgur.com/b2VBV.png

    – Vittorio Romeo
    2 days ago














    20















    Why am I allowed to create multiple unique pointers from a single object?




    You're not allowed to do that*, so it's a good thing you're not doing that!



    Don't forget, this:



    std::unique_ptr<Class> ptr = std::make_unique<Class>(a);


    is this**:



    std::unique_ptr<Class> ptr(new Class(a));


    not this:



    std::unique_ptr<Class> ptr(&a);


    std::make_unique creates a thing and gives you a unique_ptr to that thing. It does so by forwarding its arguments to the thing's constructor. Admittedly this can be confusing when you pass in the name of an existing object, leading to the copy constructor being used.



    tl;dr: You're creating copies of a.



    * Well, with a no-op deleter you could do it safely, but let's save that conversation for another day…
    ** More or less…






    share|improve this answer




















    • 1





      you can prove this to yourself by ptr2->_int = 6; and then 7 and so on. You will see that changing the Class one pointer points to has no effect on the others. They are just a bunch of copies.

      – Kate Gregory
      2 days ago











    • Cunning of you to place the TD;DR version at the bottom of the answer, guaranteeing that most people will read the the full version first. Another simple proof is to remove the copy constructor (Class(const Class &) =delete;) the copy constructor and watch the compiler choke.

      – user4581301
      2 days ago






    • 1





      @user4581301 Conclusions and summaries have been used for centuries. Feel free to write your own answer.

      – Lightness Races in Orbit
      yesterday















    20















    Why am I allowed to create multiple unique pointers from a single object?




    You're not allowed to do that*, so it's a good thing you're not doing that!



    Don't forget, this:



    std::unique_ptr<Class> ptr = std::make_unique<Class>(a);


    is this**:



    std::unique_ptr<Class> ptr(new Class(a));


    not this:



    std::unique_ptr<Class> ptr(&a);


    std::make_unique creates a thing and gives you a unique_ptr to that thing. It does so by forwarding its arguments to the thing's constructor. Admittedly this can be confusing when you pass in the name of an existing object, leading to the copy constructor being used.



    tl;dr: You're creating copies of a.



    * Well, with a no-op deleter you could do it safely, but let's save that conversation for another day…
    ** More or less…






    share|improve this answer




















    • 1





      you can prove this to yourself by ptr2->_int = 6; and then 7 and so on. You will see that changing the Class one pointer points to has no effect on the others. They are just a bunch of copies.

      – Kate Gregory
      2 days ago











    • Cunning of you to place the TD;DR version at the bottom of the answer, guaranteeing that most people will read the the full version first. Another simple proof is to remove the copy constructor (Class(const Class &) =delete;) the copy constructor and watch the compiler choke.

      – user4581301
      2 days ago






    • 1





      @user4581301 Conclusions and summaries have been used for centuries. Feel free to write your own answer.

      – Lightness Races in Orbit
      yesterday













    20












    20








    20








    Why am I allowed to create multiple unique pointers from a single object?




    You're not allowed to do that*, so it's a good thing you're not doing that!



    Don't forget, this:



    std::unique_ptr<Class> ptr = std::make_unique<Class>(a);


    is this**:



    std::unique_ptr<Class> ptr(new Class(a));


    not this:



    std::unique_ptr<Class> ptr(&a);


    std::make_unique creates a thing and gives you a unique_ptr to that thing. It does so by forwarding its arguments to the thing's constructor. Admittedly this can be confusing when you pass in the name of an existing object, leading to the copy constructor being used.



    tl;dr: You're creating copies of a.



    * Well, with a no-op deleter you could do it safely, but let's save that conversation for another day…
    ** More or less…






    share|improve this answer
















    Why am I allowed to create multiple unique pointers from a single object?




    You're not allowed to do that*, so it's a good thing you're not doing that!



    Don't forget, this:



    std::unique_ptr<Class> ptr = std::make_unique<Class>(a);


    is this**:



    std::unique_ptr<Class> ptr(new Class(a));


    not this:



    std::unique_ptr<Class> ptr(&a);


    std::make_unique creates a thing and gives you a unique_ptr to that thing. It does so by forwarding its arguments to the thing's constructor. Admittedly this can be confusing when you pass in the name of an existing object, leading to the copy constructor being used.



    tl;dr: You're creating copies of a.



    * Well, with a no-op deleter you could do it safely, but let's save that conversation for another day…
    ** More or less…







    share|improve this answer














    share|improve this answer



    share|improve this answer








    edited 2 days ago

























    answered 2 days ago









    Lightness Races in OrbitLightness Races in Orbit

    294k54477811




    294k54477811







    • 1





      you can prove this to yourself by ptr2->_int = 6; and then 7 and so on. You will see that changing the Class one pointer points to has no effect on the others. They are just a bunch of copies.

      – Kate Gregory
      2 days ago











    • Cunning of you to place the TD;DR version at the bottom of the answer, guaranteeing that most people will read the the full version first. Another simple proof is to remove the copy constructor (Class(const Class &) =delete;) the copy constructor and watch the compiler choke.

      – user4581301
      2 days ago






    • 1





      @user4581301 Conclusions and summaries have been used for centuries. Feel free to write your own answer.

      – Lightness Races in Orbit
      yesterday












    • 1





      you can prove this to yourself by ptr2->_int = 6; and then 7 and so on. You will see that changing the Class one pointer points to has no effect on the others. They are just a bunch of copies.

      – Kate Gregory
      2 days ago











    • Cunning of you to place the TD;DR version at the bottom of the answer, guaranteeing that most people will read the the full version first. Another simple proof is to remove the copy constructor (Class(const Class &) =delete;) the copy constructor and watch the compiler choke.

      – user4581301
      2 days ago






    • 1





      @user4581301 Conclusions and summaries have been used for centuries. Feel free to write your own answer.

      – Lightness Races in Orbit
      yesterday







    1




    1





    you can prove this to yourself by ptr2->_int = 6; and then 7 and so on. You will see that changing the Class one pointer points to has no effect on the others. They are just a bunch of copies.

    – Kate Gregory
    2 days ago





    you can prove this to yourself by ptr2->_int = 6; and then 7 and so on. You will see that changing the Class one pointer points to has no effect on the others. They are just a bunch of copies.

    – Kate Gregory
    2 days ago













    Cunning of you to place the TD;DR version at the bottom of the answer, guaranteeing that most people will read the the full version first. Another simple proof is to remove the copy constructor (Class(const Class &) =delete;) the copy constructor and watch the compiler choke.

    – user4581301
    2 days ago





    Cunning of you to place the TD;DR version at the bottom of the answer, guaranteeing that most people will read the the full version first. Another simple proof is to remove the copy constructor (Class(const Class &) =delete;) the copy constructor and watch the compiler choke.

    – user4581301
    2 days ago




    1




    1





    @user4581301 Conclusions and summaries have been used for centuries. Feel free to write your own answer.

    – Lightness Races in Orbit
    yesterday





    @user4581301 Conclusions and summaries have been used for centuries. Feel free to write your own answer.

    – Lightness Races in Orbit
    yesterday











    10















    Why am I allowed to create multiple unique pointers from a single object?




    You're allowed to make multiple copies of the object, because the class is copyable.




    "Unique" in unique_ptr doesn't mean that the pointed object is the unique instance of its class. It means that no other pointer should have ownership of the pointed object. In your example, each unique pointer points to a separate instance; each of the uniquely owned by the respective pointer.



    You could violate the uniqueness like this:



    std::unique_ptr<Class> ptr(&a);


    Could: The program would be well-formed and compiler would be required to compile it. But the behaviour of the program would then be undefined, so you very much should not do that.






    share|improve this answer





























      10















      Why am I allowed to create multiple unique pointers from a single object?




      You're allowed to make multiple copies of the object, because the class is copyable.




      "Unique" in unique_ptr doesn't mean that the pointed object is the unique instance of its class. It means that no other pointer should have ownership of the pointed object. In your example, each unique pointer points to a separate instance; each of the uniquely owned by the respective pointer.



      You could violate the uniqueness like this:



      std::unique_ptr<Class> ptr(&a);


      Could: The program would be well-formed and compiler would be required to compile it. But the behaviour of the program would then be undefined, so you very much should not do that.






      share|improve this answer



























        10












        10








        10








        Why am I allowed to create multiple unique pointers from a single object?




        You're allowed to make multiple copies of the object, because the class is copyable.




        "Unique" in unique_ptr doesn't mean that the pointed object is the unique instance of its class. It means that no other pointer should have ownership of the pointed object. In your example, each unique pointer points to a separate instance; each of the uniquely owned by the respective pointer.



        You could violate the uniqueness like this:



        std::unique_ptr<Class> ptr(&a);


        Could: The program would be well-formed and compiler would be required to compile it. But the behaviour of the program would then be undefined, so you very much should not do that.






        share|improve this answer
















        Why am I allowed to create multiple unique pointers from a single object?




        You're allowed to make multiple copies of the object, because the class is copyable.




        "Unique" in unique_ptr doesn't mean that the pointed object is the unique instance of its class. It means that no other pointer should have ownership of the pointed object. In your example, each unique pointer points to a separate instance; each of the uniquely owned by the respective pointer.



        You could violate the uniqueness like this:



        std::unique_ptr<Class> ptr(&a);


        Could: The program would be well-formed and compiler would be required to compile it. But the behaviour of the program would then be undefined, so you very much should not do that.







        share|improve this answer














        share|improve this answer



        share|improve this answer








        edited 2 days ago

























        answered 2 days ago









        eerorikaeerorika

        88.4k663135




        88.4k663135




















            Lokas Beard is a new contributor. Be nice, and check out our Code of Conduct.









            draft saved

            draft discarded


















            Lokas Beard is a new contributor. Be nice, and check out our Code of Conduct.












            Lokas Beard is a new contributor. Be nice, and check out our Code of Conduct.











            Lokas Beard is a new contributor. Be nice, and check out our Code of Conduct.














            Thanks for contributing an answer to Stack Overflow!


            • Please be sure to answer the question. Provide details and share your research!

            But avoid


            • Asking for help, clarification, or responding to other answers.

            • Making statements based on opinion; back them up with references or personal experience.

            To learn more, see our tips on writing great answers.




            draft saved


            draft discarded














            StackExchange.ready(
            function ()
            StackExchange.openid.initPostLogin('.new-post-login', 'https%3a%2f%2fstackoverflow.com%2fquestions%2f55420227%2fwhy-am-i-allowed-to-create-multiple-unique-pointers-from-a-single-object%23new-answer', 'question_page');

            );

            Post as a guest















            Required, but never shown





















































            Required, but never shown














            Required, but never shown












            Required, but never shown







            Required, but never shown

































            Required, but never shown














            Required, but never shown












            Required, but never shown







            Required, but never shown







            Popular posts from this blog

            getting Checkpoint VPN SSL Network Extender working in the command lineHow to connect to CheckPoint VPN on Ubuntu 18.04LTS?Will the Linux ( red-hat ) Open VPNC Client connect to checkpoint or nortel VPN gateways?VPN client for linux machine + support checkpoint gatewayVPN SSL Network Extender in FirefoxLinux Checkpoint SNX tool configuration issuesCheck Point - Connect under Linux - snx + OTPSNX VPN Ububuntu 18.XXUsing Checkpoint VPN SSL Network Extender CLI with certificateVPN with network manager (nm-applet) is not workingWill the Linux ( red-hat ) Open VPNC Client connect to checkpoint or nortel VPN gateways?VPN client for linux machine + support checkpoint gatewayImport VPN config files to NetworkManager from command lineTrouble connecting to VPN using network-manager, while command line worksStart a VPN connection with PPTP protocol on command linestarting a docker service daemon breaks the vpn networkCan't connect to vpn with Network-managerVPN SSL Network Extender in FirefoxUsing Checkpoint VPN SSL Network Extender CLI with certificate

            Cannot Extend partition with GParted The 2019 Stack Overflow Developer Survey Results Are In Announcing the arrival of Valued Associate #679: Cesar Manara Planned maintenance scheduled April 17/18, 2019 at 00:00UTC (8:00pm US/Eastern) 2019 Community Moderator Election ResultsCan't increase partition size with GParted?GParted doesn't recognize the unallocated space after my current partitionWhat is the best way to add unallocated space located before to Ubuntu 12.04 partition with GParted live?I can't figure out how to extend my Arch home partition into free spaceGparted Linux Mint 18.1 issueTrying to extend but swap partition is showing as Unknown in Gparted, shows proper from fdiskRearrange partitions in gparted to extend a partitionUnable to extend partition even though unallocated space is next to it using GPartedAllocate free space to root partitiongparted: how to merge unallocated space with a partition

            Marilyn Monroe Ny fiainany manokana | Jereo koa | Meny fitetezanafanitarana azy.