这篇文章主要为大家介绍了嵌入式C语言二级指针在链表中的应用,有需要的朋友可以借鉴参考下,希望能够有所帮助,祝大家多多进步早日升职加薪
重读了两本书:Stephen A.Maguire的《编程精粹:Microsoft编写优质无错C程序秘诀》和David R. Hanson的《C语言接口与实现:创建可重用软件的技术》。两本书都有对链表的操作。
假设有如图所示的链表,链表节点的pb成员指向一个缓冲块,删除节点函数根据缓冲块的首地址,找到节点并删除节点:

《编程精粹》使用一个变量pbiPrev来保存前一个节点位置,并且要处理删除的是第一个节点A这种边界条件:
void FreeBlockInfo(byte *pbToFree)
{
blockinfo *pbi, *pbiPrev;
pbiPrev = NULL;
for(pbi = pbiHead; pbi != NULL; pbi = pbi->pbiNext)
{
if(fPtrEqual(pbi->pb, pbToFree)
{
if(pbiPrev == NULL)
pbiHead = pbi->pbiHead;
else
pbiPrev->pbiNext = pbi->pbiNext;
break;
}
pbiPrev = pbi;
}
/*如果pbi是NULL, 说明参数pbToFree非法*/
ASSERT(pbi != NULL);
/*在释放前破坏掉要释放内存中的内容*/
memset(pbi, bGarbage, sizeof(blockinfo));
free(pbi);
}
《C语言接口与实现》使用了二级指针,可以很巧妙的省掉变量pbiPrev以及边界判断:
void FreeBlockInfo(byte *pbToFree)
{
blockinfo **ppbi, *pbiFind;
pbiFind = NULL;
for(ppbi = &pbiHead; *ppbi != NULL; ppbi = &(*ppbi)->pbiNext)
{
if(fPtrEqual((*ppbi)->pb, pbToFree)
{
pbiFind = *ppbi;
*ppbi = (*ppbi)->pbiNext;
break;
}
}
/*如果pbiFind是NULL, 说明参数pbToFree非法*/
ASSERT(pbiFind != NULL);
/*在释放前破坏掉要释放内存中的内容*/
memset(pbiFind, bGarbage, sizeof(blockinfo));
free(pbiFind);
}
以上就是嵌入式C语言二级指针在链表中的应用的详细内容,更多关于嵌入式C语言二级指针链表的资料请关注编程学习网其它相关文章!
沃梦达教程
本文标题为:嵌入式C语言二级指针在链表中的应用
基础教程推荐
猜你喜欢
- 利用QT设计秒表功能 2023-05-30
- character-encoding – Linux中最常见的C语言编码(和Unix?) 2023-11-21
- g++: const 丢弃限定符 2022-10-07
- C语言数组长度的计算方法实例总结(sizeof与strlen) 2023-04-26
- C语言的三种条件判断语句你都了解吗 2023-03-05
- C语言植物大战数据结构二叉树递归 2023-04-09
- VisualStudio2010安装教程 2023-01-05
- 05-C语言进阶——动态内存管理 2023-11-20
- Qt数据库应用之实现通用数据库请求 2023-03-18
- 纯C++代码详解二叉树相关操作 2023-05-15
