创建用 C 中的链表实现的通用堆栈
我想创建一个通用堆栈。我想用链表来实现它。
我创建了这个结构 stack_l :
typedef struct stack
{
void * data;
void (*copy)(void *o);
struct stack *next;
} stack_l;
我有一些问题:
- 结构的第二个字段是指向函数的指针,用于复制新数据(在函数 Push 中通过参数传递)。 Push函数的原型是:
stack_l * Push( stack_l * head, void * d );
- 我将指针传递给函数副本的方式是否正确?
- 我必须在 Push 函数中实现它?
- 是否有必要创建一个函数 NewStack (例如)来初始化结构体的字段,或者最好只有一个 Push 函数,如果堆栈为空,则创建第一个元素,如果至少有一个元素,则在顶部添加新元素元素?
- void * 需要用 malloc 分配吗?
I want to create a generic stack. I want to implement it with a linked-list.
I created this structures stack_l :
typedef struct stack
{
void * data;
void (*copy)(void *o);
struct stack *next;
} stack_l;
I have some questions:
- The second field of the structures is a pointer to a function, to copy a new data (passing by argument in a function Push).
The prototype of the function Push is:
stack_l * Push( stack_l * head, void * d );
- Is it correct how I pass the pointer to the function copy?
- I have to implement it in the function Push??
- Is it necessary create a function NewStack (for example) to inizialize the field of the structures, or is better have only a Push function that create the 1st element if the stack is empty, and add new element on top if there is at least one element?
- A void * need to be allocated with a malloc ?
如果你对这篇内容有疑问,欢迎到本站社区发帖提问 参与讨论,获取更多帮助,或者扫码二维码加入 Web 技术交流群。
绑定邮箱获取回复消息
由于您还没有绑定你的真实邮箱,如果其他用户或者作者回复了您的评论,将不能在第一时间通知您!
发布评论
评论(1)
首先,您不需要
stack
和stack_l
使用不同的标识符。现在,回答您的问题:您的
Push
函数与stack_l
中的copy
字段的类型不兼容。如果您想在struct
中包含指向(成员)函数的指针以使其看起来像 C++,您仍然需要将对象传递给这些函数。是的,您必须在某个地方实现您的功能,并且不能在
struct stack
的定义范围内。这意味着您确实需要某种构造函数(如果您愿意,您可以将其称为newStack
)。您的构造函数必须至少初始化您的函数指针(如果您想保留它们)。如果您选择不保留这些函数指针,您可以将初始化代码很好地放在您的push
例程中,正如您所建议的:请注意,您必须明确说明空堆栈是什么。因此,为了清楚起见,您可能想要实现一个构造函数:
甚至可能是一个析构函数:
对于最后一个问题:正如您在上面看到的,您必须使用
malloc
来获取空间来保存您的stack_l< /code> 对象,除此之外,您不需要为
void*
成员分配额外的空间,因为它是stack_l
的一部分。First of all, you do not require different identifiers for
stack
andstack_l
. Now, to your questions:Your
Push
function is incompatible with the type of thecopy
field instack_l
. If you want to include a pointer to (member-)functions in yourstruct
to make it look like C++, you still have to pass your object to these functions.Yes ,you have to implement your functionality somewhere, and that cannot be within the definition of
struct stack
. This means that you do need some sort of constructor function (you may call itnewStack
if you like). Your constructor must at least initialise your function pointers (if you want to keep them). If you opt not to keep these function pointers you can put the initialisation code well in yourpush
routine, as you suggested:Note that you have to explicitly state what the empty stack is. So you may want to implement a constructor for clarity:
And maybe even a destructor:
To your last question: As you see above, you have to use
malloc
to get space to hold yourstack_l
object, other than that, you do not need to allocate extra space for yourvoid*
member, as it is part ofstack_l
.