首页
学习
活动
专区
圈层
工具
发布
首页
学习
活动
专区
圈层
工具
MCP广场
社区首页 >问答首页 >无法理解(struct Stack* stack)

无法理解(struct Stack* stack)
EN

Stack Overflow用户
提问于 2021-02-01 17:15:31
回答 1查看 19关注 0票数 0
代码语言:javascript
运行
复制
struct Stack* create(int max) { 
struct Stack *stack = (struct Stack*)malloc(sizeof(struct Stack)); 
stack->maxSize = max; 
stack->top = -1; 
stack->array = (int*)malloc(stack->maxSize * sizeof(int));
return stack; }
 int isFull(struct Stack* stack) 
 { 
       if(stack->top == stack->maxSize - 1)
 {
         printf("STACKOVERFLOW\n");
 }
        return stack->top == stack->maxSize - 1; 
 } 

在这个问题中struct Stack* stack的用途是什么?

我试图理解堆栈,但不能理解为什么我们必须使用这个结构堆栈*堆栈

EN

回答 1

Stack Overflow用户

发布于 2021-02-02 00:49:47

代码动态分配(可能是*)用作堆栈的内部数组。这使实现者不必预先定义一个或多个固定长度的数组,这将是浪费的。动态分配数据结构的使用使代码变得灵活。假设这是直接的C代码,并且将代码实现为结构可以为您提供接近实际面向对象语言中的实际对象的优点(例如,部分但不是真正的数据隐藏)。

*我不得不说,可能是因为代码除了检查堆栈是否已满之外,也没有实现任何明确的堆栈操作(isFull() )。

票数 0
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/65989972

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档