当前位置: 首页 > wzjs >正文

广西建设科技协会网站首页国外做ic的网站

广西建设科技协会网站首页,国外做ic的网站,办公空间设计案例ppt,安卓app快速开发文章目录 前言一、系统设计要点二、核心数据结构2.1 设备唯一标识(DeviceUID)2.2 节点信息(Node)2.3 节点管理器(NodeManager) 三、核心算法实现3.1 初始化与清理3.1.1 初始化节点管理器3.1.2 清理节点管理器 3.2 动态ID分配策略3.2.1 查找最小可用ID3.2.2 ID使用检查 3.3 心跳…

文章目录

  • 前言
  • 一、系统设计要点
  • 二、核心数据结构
    • 2.1 设备唯一标识(DeviceUID)
    • 2.2 节点信息(Node)
    • 2.3 节点管理器(NodeManager)
  • 三、核心算法实现
    • 3.1 初始化与清理
      • 3.1.1 初始化节点管理器
      • 3.1.2 清理节点管理器
    • 3.2 动态ID分配策略
      • 3.2.1 查找最小可用ID
      • 3.2.2 ID使用检查
    • 3.3 心跳处理机制
    • 3.4 超时检测机制
  • 四、节点查找与管理
    • 4.1 通过UID查找节点
    • 4.2 通过ID查找节点
    • 4.3 获取活跃节点列表
  • 五、回调机制实现
    • 5.1 回调函数注册
    • 5.2 示例回调函数
  • 六、应用示例
  • 七、总结


前言

在嵌入式设备网络中,节点的动态加入与退出是常态,尤其是在无人机、传感器网络、智能家居等系统中,节点通常无法提前预设 ID,这就要求系统具备动态 ID 分配与管理能力。本篇博客将围绕“动态 ID 管理”这一核心,介绍一个基于设备 UID 的动态 ID 分配系统,支持重复上线检测、最小可用 ID 分配、ID 冲突检测、ID 释放与复用等功能,代码完全由 C 语言实现,结构清晰,易于移植与扩展。


一、系统设计要点

该系统以节点唯一标识符 DeviceUID 为基础,实现了以下关键特性:

  • 动态 ID 分配:无需提前为设备分配 ID,系统自动为新设备分配最小可用 ID。

  • UID 唯一识别机制:通过对 UID 的比较实现节点重复检测与状态更新。

  • ID 冲突检测:避免多个设备使用相同 ID 导致状态混乱。

  • ID 释放与复用:支持节点主动释放 ID,或超时后自动回收,以复用资源。

  • 回调机制:支持注册上线、下线回调函数,便于系统业务集成。

  • 心跳检测:通过心跳机制维护节点活跃状态

  • 超时处理:自动检测并清理离线节点

二、核心数据结构

2.1 设备唯一标识(DeviceUID)

typedef struct {uint8_t bytes[6];  // 6字节的唯一设备标识
} DeviceUID;

这个结构体用于存储设备的唯一标识符,通常可以是MAC地址或其他硬件唯一ID。

2.2 节点信息(Node)

typedef struct Node {uint8_t id;          // 分配的节点IDDeviceUID uid;       // 设备唯一标识uint64_t lastSeenMs; // 最后活跃时间戳(毫秒)struct Node* next;   // 下一个节点指针
} Node;

每个节点包含分配的ID、设备唯一标识、最后活跃时间和指向下一个节点的指针。

2.3 节点管理器(NodeManager)

typedef struct {Node* head;                  // 链表头指针uint8_t activeCount;         // 活跃节点计数NodeOnlineCallback onOnline; // 节点上线回调函数NodeOfflineCallback onOffline; // 节点下线回调函数
} NodeManager;

节点管理器维护所有活跃节点的链表,并提供回调函数接口。

三、核心算法实现

3.1 初始化与清理

3.1.1 初始化节点管理器

void NodeManager_Init(NodeManager* manager) {manager->head = NULL;manager->activeCount = 0;manager->onOnline = NULL;manager->onOffline = NULL;
}

3.1.2 清理节点管理器

void NodeManager_Cleanup(NodeManager* manager) {Node* current = manager->head;while (current) {Node* next = current->next;// 回调通知节点离线if (manager->onOffline) {manager->onOffline(current->id, &current->uid);}free(current);current = next;}manager->head = NULL;manager->activeCount = 0;
}

3.2 动态ID分配策略

3.2.1 查找最小可用ID

static uint8_t FindMinAvailableID(NodeManager* manager) {for (uint8_t id = MIN_VALID_ID; id <= MAX_VALID_ID; id++) {if (!IsIDUsed(manager, id)) return id;}return INVALID_ID;
}

该算法从MIN_VALID_ID开始遍历,返回第一个未被使用的ID。

3.2.2 ID使用检查

static bool IsIDUsed(NodeManager* manager, uint8_t id) {Node* current = manager->head;while (current) {if (current->id == id) return true;current = current->next;}return false;
}

3.3 心跳处理机制

uint8_t ProcessHeartbeat(NodeManager* manager, uint8_t nodeId, const DeviceUID* uid) {// 1. 检查是否已有相同UID的节点Node* existing = FindNodeByUID(manager, uid);if (existing) {existing->lastSeenMs = GetSysTimeMs(); // 更新活跃时间return existing->id;}// 2. 检查请求的ID是否已被占用if (nodeId != INVALID_ID && FindNodeByID(manager, nodeId)) {nodeId = INVALID_ID; // 如果已被占用,则重置为无效ID}// 3. 分配新IDif (nodeId == INVALID_ID) {nodeId = FindMinAvailableID(manager);if (nodeId == INVALID_ID) return INVALID_ID; // 无可用ID}// 4. 添加新节点return AddNode(manager, nodeId, uid) ? nodeId : INVALID_ID;
}
  • 心跳处理流程

    1. 如果是已知节点,更新其活跃时间

    2. 如果是新节点,检查请求ID是否可用

    3. 分配最小可用ID

    4. 添加新节点到管理器

3.4 超时检测机制

void CheckTimeoutNodes(NodeManager* manager) {uint64_t now = GetSysTimeMs();Node** pnode = &manager->head;while (*pnode) {Node* current = *pnode;if ((now - current->lastSeenMs) > HEARTBEAT_TIMEOUT) {*pnode = current->next; // 从链表中移除// 回调通知节点离线if (manager->onOffline) {manager->onOffline(current->id, &current->uid);}free(current); // 释放节点内存manager->activeCount--;} else {pnode = &(*pnode)->next;}}
}

该函数遍历所有节点,检查最后活跃时间是否超时,超时则移除节点并触发下线回调。

四、节点查找与管理

4.1 通过UID查找节点

static Node* FindNodeByUID(NodeManager* manager, const DeviceUID* uid) {Node* current = manager->head;while (current) {if (CompareDeviceUID(&current->uid, uid)) return current;current = current->next;}return NULL;
}

4.2 通过ID查找节点

static Node* FindNodeByID(NodeManager* manager, uint8_t id) {Node* current = manager->head;while (current) {if (current->id == id) return current;current = current->next;}return NULL;
}

4.3 获取活跃节点列表

uint8_t GetActiveNodeIDs(NodeManager* manager, uint8_t* outputBuffer, uint8_t bufferSize) {uint8_t count = 0;Node* current = manager->head;while (current && count < bufferSize) {outputBuffer[count++] = current->id;current = current->next;}qsort(outputBuffer, count, sizeof(uint8_t), CompareNodeIDs);return count;
}

五、回调机制实现

5.1 回调函数注册

void NodeManager_RegisterCallbacks(NodeManager* manager, NodeOnlineCallback onOnline, NodeOfflineCallback onOffline) {manager->onOnline = onOnline;manager->onOffline = onOffline;
}

5.2 示例回调函数

void OnNodeOnline(uint8_t id, const DeviceUID* uid) {printf("[Callback] Node %d is ONLINE!\n", id);
}void OnNodeOffline(uint8_t id, const DeviceUID* uid) {printf("[Callback] Node %d is OFFLINE!\n", id);
}

六、应用示例

void TestNodeManager() {NodeManager manager;NodeManager_Init(&manager);// 注册回调NodeManager_RegisterCallbacks(&manager, OnNodeOnline, OnNodeOffline);// 模拟设备UIDDeviceUID uid1 = {{0x00, 0x11, 0x22, 0x33, 0x44, 0x55}};DeviceUID uid2 = {{0x66, 0x77, 0x88, 0x99, 0xAA, 0xBB}};// 节点上线ProcessHeartbeat(&manager, 1, &uid1);  // 指定ID=1ProcessHeartbeat(&manager, INVALID_ID, &uid2);  // 自动分配ID// 打印活跃节点PrintActiveNodes(&manager);// 模拟超时printf("\nSimulating timeout...\n");GetSysTimeMs();  // 模拟时间流逝CheckTimeoutNodes(&manager);PrintActiveNodes(&manager);// 主动释放节点printf("\nManually releasing node...\n");ReleaseNodeID(&manager, 2);PrintActiveNodes(&manager);// 清理NodeManager_Cleanup(&manager);
}

七、总结

本文详细介绍了一个高效的动态ID管理系统的设计与实现,该系统具有以下优点:

  • 灵活性:支持动态ID分配和释放

  • 可靠性:通过心跳机制确保节点状态准确

  • 可扩展性:易于添加新功能如安全验证等

  • 低开销:内存占用小,适合嵌入式环境

  • 事件驱动:通过回调机制实现松耦合

这种动态ID管理方案非常适合物联网设备、传感器网络等需要管理大量动态节点的嵌入式应用场景。


文章转载自:

http://PDmIGZOA.pLjdy.cn
http://5AAgnawK.pLjdy.cn
http://h4q3WVrq.pLjdy.cn
http://bsYMwAxz.pLjdy.cn
http://oGBkZWjj.pLjdy.cn
http://QVuD2owh.pLjdy.cn
http://lCgGYsIF.pLjdy.cn
http://fqRLQL59.pLjdy.cn
http://KwMfE1Gi.pLjdy.cn
http://k6Xc28ka.pLjdy.cn
http://YuRkwulo.pLjdy.cn
http://TV8xR8QL.pLjdy.cn
http://TapBCjUz.pLjdy.cn
http://Tvk3liMa.pLjdy.cn
http://aVS1MM7t.pLjdy.cn
http://nJOUlZCu.pLjdy.cn
http://JftopRDG.pLjdy.cn
http://3LXMyPvA.pLjdy.cn
http://oJYkXhhV.pLjdy.cn
http://5LD97Rc4.pLjdy.cn
http://SLx7Ot8V.pLjdy.cn
http://4CBd5itX.pLjdy.cn
http://qrcVwqVL.pLjdy.cn
http://PlNlF82t.pLjdy.cn
http://TFACiI6N.pLjdy.cn
http://SHalMF4r.pLjdy.cn
http://kHlGvJLG.pLjdy.cn
http://PVcw3gCO.pLjdy.cn
http://hXnFMDJJ.pLjdy.cn
http://LPHFIg9E.pLjdy.cn
http://www.dtcms.com/wzjs/724138.html

相关文章:

  • 怎么给自己的网站做排名德吉机械东莞网站建设
  • 淮南做网站的公司有哪些海南第四建设工程有限公司网站
  • 科技资讯 哪个网站好基于php技术的个人网站设计
  • 自助建站软件下载天津网站建设方案
  • 做电商需要知道的几个网站吗wordpress二维码
  • 郴州网站建设公司哪家好建湖网站优化公司
  • 不同类型网站优势备案时的网站建设方案书
  • 怎么做自己网站里的资讯网站开发组件拖拽
  • 网站建设策划内容网站下载app连接怎么做
  • 佛山教育平台网站建设做家装施工的网站
  • 摄影工作室网站设计绿色网站风格
  • 个人做电商网站网站开发未按合同约定开发时间完工
  • 网站建设设计制作 熊掌号网站设计建设有限公司
  • 温州手机网站制作哪家便宜wordpress英文站源码
  • 手机网站模板建站梦幻西游网页版官方网站
  • app与网站的区别如何制作私人网站
  • 淘宝买cdk自己做网站ui做网站流程
  • 宁波本地模板网站建设平台网站一直被攻击怎么办
  • 青秀网站建设做一个网站维护多少钱
  • php网站开发环境不良网站代码怎么查
  • 怎么建设国际网站首页哈密地网站建设
  • 兰州 网站建设公司哪家好网站建设源码导入
  • 小网站文案ueditor wordpress 4.5
  • 网站建设流程发布网站和网页制作html5视频播放器插件
  • 珠海横琴建设局网站营销型网站设计思路
  • 美工需要的网站做教育网站的公司
  • 简单网站页面wordpress 火车头发布规则
  • 企业网站源码安装教程施工企业资质序列
  • 南昌行业网站建设苏州技术馆网站建设
  • 郑州高端网站公司淘宝店标在线制作免费