博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
NFC 鏈表操作
阅读量:6343 次
发布时间:2019-06-22

本文共 4431 字,大约阅读时间需要 14 分钟。

/* * Copyright (C) 2010 The Android Open Source Project * * Licensed under the Apache License, Version 2.0 (the "License"); * you may not use this file except in compliance with the License. * You may obtain a copy of the License at * *      http://www.apache.org/licenses/LICENSE-2.0 * * Unless required by applicable law or agreed to in writing, software * distributed under the License is distributed on an "AS IS" BASIS, * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. * See the License for the specific language governing permissions and * limitations under the License. */#include 
#include
#include
#include
#include
#undef LOG_TAG#define LOG_TAG "NFC_LIST"bool listInit(listHead* pList){ pList->pFirst = NULL; if(pthread_mutex_init(&pList->mutex, NULL) == -1) { ALOGE("Mutex creation failed (errno=0x%08x)", errno); return false; } return true;}bool listDestroy(listHead* pList){ bool bListNotEmpty = true; while (bListNotEmpty) { bListNotEmpty = listGetAndRemoveNext(pList, NULL); } if(pthread_mutex_destroy(&pList->mutex) == -1) { ALOGE("Mutex destruction failed (errno=0x%08x)", errno); return false; } return true;}bool listAdd(listHead* pList, void* pData){ struct listNode* pNode; struct listNode* pLastNode; bool result; /* Create node */ pNode = (struct listNode*)malloc(sizeof(listNode)); if (pNode == NULL) { result = false; ALOGE("Failed to malloc"); goto clean_and_return; } TRACE("Allocated node: %8p (%8p)", pNode, pData); pNode->pData = pData; pNode->pNext = NULL; pthread_mutex_lock(&pList->mutex); /* Add the node to the list */ if (pList->pFirst == NULL) { /* Set the node as the head */ pList->pFirst = pNode; } else { /* Seek to the end of the list */ pLastNode = pList->pFirst; while(pLastNode->pNext != NULL) { pLastNode = pLastNode->pNext; } /* Add the node to the current list */ pLastNode->pNext = pNode; } result = true;clean_and_return: pthread_mutex_unlock(&pList->mutex); return result;}bool listRemove(listHead* pList, void* pData){ struct listNode* pNode; struct listNode* pRemovedNode; bool result; pthread_mutex_lock(&pList->mutex); if (pList->pFirst == NULL) { /* Empty list */ ALOGE("Failed to deallocate (list empty)"); result = false; goto clean_and_return; } pNode = pList->pFirst; if (pList->pFirst->pData == pData) { /* Get the removed node */ pRemovedNode = pNode; /* Remove the first node */ pList->pFirst = pList->pFirst->pNext; } else { while (pNode->pNext != NULL) { if (pNode->pNext->pData == pData) { /* Node found ! */ break; } pNode = pNode->pNext; } if (pNode->pNext == NULL) { /* Node not found */ result = false; ALOGE("Failed to deallocate (not found %8p)", pData); goto clean_and_return; } /* Get the removed node */ pRemovedNode = pNode->pNext; /* Remove the node from the list */ pNode->pNext = pNode->pNext->pNext; } /* Deallocate the node */ TRACE("Deallocating node: %8p (%8p)", pRemovedNode, pRemovedNode->pData); free(pRemovedNode); result = true;clean_and_return: pthread_mutex_unlock(&pList->mutex); return result;}bool listGetAndRemoveNext(listHead* pList, void** ppData){ struct listNode* pNode; bool result; pthread_mutex_lock(&pList->mutex); if (pList->pFirst) { /* Empty list */ ALOGE("Failed to deallocate (list empty)"); result = false; goto clean_and_return; } /* Work on the first node */ pNode = pList->pFirst; /* Return the data */ if (ppData != NULL) { *ppData = pNode->pData; } /* Remove and deallocate the node */ pList->pFirst = pNode->pNext; TRACE("Deallocating node: %8p (%8p)", pNode, pNode->pData); free(pNode); result = true;clean_and_return: listDump(pList); pthread_mutex_unlock(&pList->mutex); return result;}void listDump(listHead* pList){ struct listNode* pNode = pList->pFirst; TRACE("Node dump:"); while (pNode != NULL) { TRACE("- %8p (%8p)", pNode, pNode->pData); pNode = pNode->pNext; }}

转载于:https://www.cnblogs.com/yuzaipiaofei/p/4124109.html

你可能感兴趣的文章
【python】-- web开发之HTML
查看>>
vs2015 去除 git 源代码 绑定
查看>>
解决firefox的button按钮文字不能垂直居中
查看>>
网络协议端口号详解
查看>>
大话数据结构读后感——第一章
查看>>
各种排序
查看>>
ts 格式化日期输出
查看>>
Optional
查看>>
sed 命令编辑文本
查看>>
LRUCache 具体解释
查看>>
Activity调用isDestroyed()方法报出,java.lang.NoSuchMethodError
查看>>
使用AFNetworking第三方下载类
查看>>
fhq-treap小结
查看>>
about porting
查看>>
MySQL事务及ACID特性
查看>>
Hadoop_31_MapReduce参数优化
查看>>
linux运维常见英文报错中文翻译(菜鸟必知)
查看>>
[原][osgEarth]添加自由飞行漫游器
查看>>
代码审查 Code Review
查看>>
fastjson如何指定字段不序列化
查看>>