2

在 C++ 中,函数如何处理退出函数范围时动态分配的内存?这块内存是被清除了,还是可以传回主块?

在上下文中:我有一个函数,我将一个指向 double 的指针传递给它作为一个数组。我在函数内动态分配内存,初始化元素并退出函数。

            void my_func(double* ptr){
            ptr = new double[2];
            ptr[0] = 15; ptr[1] = 10;
            }

在主块中,我然后使用新分配的数组。

            int main(){
            double* ptr;
            my_func(ptr);
            cout << ptr[0] + ptr[1] << endl;
            delete[] ptr;
            return 0;

这行得通吗?这种方法是否存在危险/陷阱?

4

2 回答 2

11

在 C++ 中,函数如何处理退出函数范围时动态分配的内存?这块内存是被清除了,还是可以传回主块?

在 C++ 中,手动(动态)分配的内存必须手动释放。

在上下文中:我有一个函数,我将一个指向 double 的指针传递给它作为一个数组。我在函数内动态分配内存,初始化元素并退出函数。

您正在按值获取指针,因此虽然您可以更改指针指向的内容,但您不能更改指针本身。这样做只会更改指针的本地副本。如果您通过引用获取指针,那么它将起作用:

void my_func(double*& ptr)
{
    ptr = new double[2];
    ptr[0] = 15; ptr[1] = 10;
}

这行得通吗?这种方法是否存在危险/陷阱?

它大部分都可以工作,但由于相关的陷阱,它不是 C++ 的方式。最好使用vector

std::vector<int> my_func()
{
    std::vector<int> buffer;
    buffer.push_back(15);
    buffer.push_back(10);
    return buffer;
}
于 2012-05-30T15:39:26.493 回答
0

这行得通吗?这种方法是否存在危险/陷阱?

只要没有出错,它就可以工作。如果抛出异常,它通常会泄漏内存。为避免这种情况,您通常希望释放某个类的析构函数中的内存,然后创建具有自动存储持续时间的该类的实例。这意味着它会在超出范围时被销毁,并且会(反过来)释放它所控制的内存。

标准库已经有各种容器可以做到这一点。你所拥有的最接近 a std::vector,但也有std::dequestd::list等等。

于 2012-05-30T16:28:36.937 回答