How to Convert beween Stack and Heap Objects

前端 未结 7 807
暖寄归人
暖寄归人 2021-01-05 23:16

Example:

Class *_obj1;
Class *_obj2;

void doThis(Class *obj) {}

void create() {
    Class *obj1 = new Class();
    Class obj2;

    doThis(obj1);
    doThi         


        
相关标签:
7条回答
  • 2021-01-05 23:22

    You have to either copy-construct a new heap object (Class * foo = new Class(obj2)) or assign the stack object to a heap object (*obj1 = obj2).

    0 讨论(0)
  • 2021-01-05 23:22

    Taking the address of a stack variable won't magically transfer it into heap. You need to write a proper copy-constructor for your class and use _obj2 = new Class(obj2);.

    As for STL containers, they allocate their data on the heap anyway, why would you want to allocate container itself on the heap? Put them in a scope that will keep them alive as long as you need them.

    0 讨论(0)
  • 2021-01-05 23:30

    So, the first question is: if how can I convert the stack object (obj2) to a heap object so it's not deallocated after create() exits?

    This line:

    _obj2 = &obj2;
    

    Change to:

    _obj2 = new Class(obj2);  // Create an object on the heap invoking the copy constructor.
    

    I want a straight answer, not an arrogant "you're doing it wrong" as so many have done.

    Thats as straight an answer as you can get. Obviously you are new to C++, So I am sure this will nto work as intended because you have probably made a couple of mistakes in the defintion of the class "Class" (by the way terrible name).

    Also, converting back to a stack object would be useful as well.

    class obj3(*_obj2);  // dereference the heap object pass it to the copy constructor.
    

    The second question: the specific example of heap objects being "wrong" was creating a new vector<string>* using the new operator. If dynamically allocating STL objects is wrong, then what's the right way?

    Why do you dynamically allocate the vector. Just create it locally.

    std::vector<std::string> funct()
    {
        std::vector<std::string>   vecString;
        // fill your vector here.
    
        return vecString;  // Notice no dynamic allocation with new,
    }
    

    Using new/delete is using C++ like C. What you need to read up on is smart pointers. These are obejcts that control the lifespan of the object and automatically delete the object when they go out of scope.

    std::auto_ptr<Class>   x(new Class);
    

    Here x is a smart pointer (of type auto_ptr) when it goes out of scope the object will be deleted. But you can return an auto_ptr to the calling function and it will be safely transfered out of the function. Its actually a lot more complicated than that and you need a book.

    Obviously if you create them as stack objects it fails because they're immediately deallocated,

    Its de'allocated when it goes out of scope.

    but I've been told (again, by a very high-ranking member) that dynamically allocating them can corrupt the heap.

    If you do it incorrectly. Which given your knowledge is very likely. But hard to verify since you have not provided the definition of Class.

    So what's the right way to do it?

    1. Learn why you should use stack objects
    2. Learn what smart pointers are.
    3. Learn how to use smart pointers to control lifespans of objects.
    4. Learn the different types of smart pointers.
    5. Look up what the separation of concerns is (you are not following this basic principle).
    0 讨论(0)
  • 2021-01-05 23:32

    Your stack object is created inside the create function and is deallocated as soon you get out of scope of the function. The pointer is invalid.

    You could change Class* obj2 to Class obj2 and the assign (which means copy) the object by obj2 = obj2;

    0 讨论(0)
  • 2021-01-05 23:33

    So, the first question is: if how can I convert the stack object (obj2) to a heap object so it's not deallocated after create() exits? I want a straight answer,

    The straight answer is: You can't "convert" an object between the stack and heap. You can create a copy of the object that lives in the other space, as others have pointed out, but that's it.

    The second question: the specific example of heap objects being "wrong" was creating a new vector* using the new operator. If dynamically allocating STL objects is wrong, then what's the right way? Obviously if you create them as stack objects it fails because they're immediately deallocated, but I've been told (again, by a very high-ranking member) that dynamically allocating them can corrupt the heap.

    Dynamically allocating STL objects will not on its own corrupt the heap. (No idea where you might have heard that.)

    If you want to use a stack-allocated STL object outside of the function that you created it in, you can't, since the stack space in which the object resides is only valid inside the function that created it.

    You can, however, return a copy of the object:

    std::vector<char> SomeFunc()
    {
        std::vector<char> myvector;
        // myvector.operations ...
        return myvector;
    }
    

    As I said, though, this will return a copy of the object, not the original object itself -- that would be impossible, since the stack that contains the object is unwound after the function returns.

    One other option is to have the caller pass in a reference / pointer to the object that your function manipulates, if this makes sense for your particular scenario:

    void SomeFunc(std::vector<char>& destination)
    {
        // destination.operations ...
    }
    
    void AnotherFunc()
    {
        std::vector<char> myvector;
        SomeFunc(myvector);
    }
    

    As you can see, you've still allocated everything on the stack, and you avoid the (sometimes consequential) overhead of relying on the copy-constructor to return a copy of the object.

    0 讨论(0)
  • 2021-01-05 23:37

    the only way is to copy object.

    Change declaration to:

    Class _obj2;

    and assign:

    _obj2 = obj2;

    0 讨论(0)
提交回复
热议问题