gpt4 book ai didi

c++ - 动态内存控制的优点是什么?

转载 作者:行者123 更新时间:2023-11-30 01:49:33 24 4
gpt4 key购买 nike

比如我想做一个栈。我可以这样做,使用动态内存控制,使用 newdelete 操作:

#include <iostream>

using namespace std;

struct List
{
int x;
List *Next,*Head;
};


void Add(int x, List *&MyList)
{
List *temp=new List;
temp->x=x;
temp->Next=MyList->Head;
MyList->Head=temp;
}


void Show(List *MyList)
{
List *temp=MyList->Head;

while (temp!=NULL)
{
cout<<temp->x<<" ";
temp=temp->Next;
}
}


void ClearList(List *MyList)
{
while (MyList->Head!=NULL)
{
List *temp=MyList->Head->Next;
delete MyList->Head;
MyList->Head=temp;
}
}

int main()
{


List *MyList=new List;


MyList->Head=NULL;

for (int i=0;i<10;i++) Add(i,MyList);
Show(MyList);

ClearList(MyList);
delete MyList->Head;
delete MyList;
}

而且我也可以用这种方式制作一个堆栈并用它做任何事情:

std::stack<int> MyStack;

那么,哪个更好呢?具有动态内存分配的堆栈有什么优势?在什么情况下我应该使用第一/第二变体?

最佳答案

两个堆栈都为它们的节点使用动态分配的内存(尽管对于 std::stack 它取决于底层容器)。当然最好使用标准类。它已经由合格的程序员测试和编写,并且足够灵活:您可以使用多个标准容器来实现堆栈,因为标准堆栈是一个容器适配器。

事实上,你可以为 std::stack 编写你自己的底层容器,例如一个数组的包装器,在这种情况下,整个堆栈将被放置在堆栈内存中,尽管它的大小当然是固定的。:)

然而,标准堆栈也有许多缺点。例如,您不能使用 std::forward_list 作为底层容器。我提议为 std::forward_list 专门化标准类 std::stack

关于c++ - 动态内存控制的优点是什么?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/28915865/

24 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com