如何解决如果我使用memmove在C语言中删除链表中的节点,会更有效吗?
我在互联网上遇到的有关删除链表中的节点的每个示例,他们都使用此方法删除第一个节点:
Algorithm to delete first node of Singly Linked List
%%Input: head of the linked list
Begin:
If (head != NULL) then
toDelete ← head
head ← head.next
unalloc (toDelete)
End if
End
在此代码中,他们从那里的列表中删除了第一个节点后,他们释放了内存区域。 但是我正在使用memove()删除链接列表的第一个节点。
...
if (key == 1){
memmove(head,head->next,sizeof(node));
return;
}
...
因此,当我使用memmove()时,它会自动释放内存区域吗? 而且我的代码更有效吗?
解决方法
在您的代码中, head 是一个标量指针,因此使用 memmove 不会比简单的赋值更快。复制大型对象时, memmove 功能会很有用。
版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。