代码拉取完成,页面将自动刷新
同步操作将从 格维开源社区/FreeMQ 强制同步,此操作会覆盖自 Fork 仓库以来所做的任何修改,且无法恢复!!!
确定后同步将在后台操作,完成时将刷新页面,请耐心等待。
#include "FreeMQ.h"
//#define FR_DEBUG_EN
#ifdef FR_DEBUG_EN
#include "STDIO.H"
#endif
#ifndef NULL
#define NULL ((void *)0)
#endif
struct FreeMQ FreeMainMQ; //主任务
//空的列表
static u8 FreeMQIsEmpty(struct FreeMQ *mq)
{
if (mq->firstmsg == NULL)
{
return 1;
}
return 0;
}
//查找下一个存放消息的索引
static struct FreeMQMessage *FreeMQNewMessage(struct FreeMQ *mq)
{
u8 msgindex;
for (msgindex = 0; msgindex < MAXMSGCOUNT; msgindex++)
{
if (mq->msglist[msgindex].messageId == EMPTYMSGID)
{
return &(mq->msglist[msgindex]);
}
}
return NULL;
}
//删除某个消息
static void FreeMQRemoveMessage(struct FreeMQ *mq, struct FreeMQMessage *prevmsg, struct FreeMQMessage *currmsg)
{
if (mq->lastmsg == currmsg)
{
mq->lastmsg = prevmsg;
}
if (mq->firstmsg == currmsg)
{
mq->firstmsg = currmsg->nextMsg;
}
if (prevmsg != NULL)
{
prevmsg->nextMsg = currmsg->nextMsg;
}
currmsg->messageId = EMPTYMSGID;
}
//初始化任务
void FreeMQInit(struct FreeMQ *mq, void (*dispatchfun)(u8 messageId))
{
mq->dispatchhandler = (FreeMQProcessHandle)dispatchfun;
FreeMQClearMessages(mq);
}
//复位时间戳
void FreeMQResetTime(struct FreeMQ *mq)
{
struct FreeMQMessage *currmsg;
currmsg = mq->firstmsg;
while (currmsg != NULL)
{
if (currmsg->timeStamp <= mq->timeTick)
{
currmsg->timeStamp = 0;
}
else
{
currmsg->timeStamp = currmsg->timeStamp - mq->timeTick;
}
currmsg = currmsg->nextMsg;
}
mq->timeTick = 0;
}
//任务时钟
void FreeMQTick(struct FreeMQ *mq, u32 tick)
{
mq->timeTick = mq->timeTick + tick;
if (mq->timeTick > 0xFF000000)
{
//还有4小时就要爆了,重置下
FreeMQResetTime(mq);
}
}
//取消未执行的消息
u8 FreeMQCancelMessages(struct FreeMQ *mq, u8 messageId)
{
struct FreeMQMessage *prevmsg;
struct FreeMQMessage *currmsg;
u8 cancelcount;
if (FreeMQIsEmpty(mq))
{
return 0;
}
cancelcount = 0;
prevmsg = NULL;
currmsg = mq->firstmsg;
while (currmsg != NULL)
{
if (currmsg->messageId == messageId)
{
//删除掉
FreeMQRemoveMessage(mq, prevmsg, currmsg);
currmsg = currmsg->nextMsg;
cancelcount++;
continue;
}
prevmsg = currmsg;
currmsg = currmsg->nextMsg;
}
return cancelcount;
}
//添加延迟处理消息
void FreeMQSendMessageLater(struct FreeMQ *mq, u8 messageId, u32 delayms)
{
struct FreeMQMessage *newmsg;
FreeMQCancelMessages(mq,messageId);//默认一个消息ID只存在一个,有需要重复的可以注释此行
newmsg = FreeMQNewMessage(mq);
if (newmsg == NULL)
{
#ifdef FR_DEBUG_EN
printf("Pool full,send cancel!\n");
#endif
return; //消息池已满无法添加
}
newmsg->messageId = messageId;
newmsg->timeStamp = mq->timeTick + delayms;
newmsg->nextMsg = NULL;
if (FreeMQIsEmpty(mq))
{ //空的
mq->firstmsg = newmsg;
mq->lastmsg = newmsg;
}
else
{
mq->lastmsg->nextMsg = newmsg;
mq->lastmsg = newmsg;
}
}
//清除所有消息
void FreeMQClearMessages(struct FreeMQ *mq)
{
u8 msgindex;
mq->firstmsg = NULL;
mq->lastmsg = NULL;
mq->timeTick = 0;
for (msgindex = 0; msgindex < MAXMSGCOUNT; msgindex++)
{
mq->msglist[msgindex].messageId = EMPTYMSGID;
}
}
//所有空闲时间时触发
void FreeMQLoop(struct FreeMQ *mq)
{
struct FreeMQMessage *prevmsg;
struct FreeMQMessage *currmsg;
if (FreeMQIsEmpty(mq))
{
return;
}
prevmsg = NULL;
currmsg = mq->firstmsg;
while (currmsg != NULL)
{
if (currmsg->timeStamp <= mq->timeTick)
{
u8 handlemessageid = currmsg->messageId;
FreeMQRemoveMessage(mq, prevmsg, currmsg);
//处理到期的消息
mq->dispatchhandler(handlemessageid);
//匹配到了
return;
}
prevmsg = currmsg;
currmsg = currmsg->nextMsg;
}
}
此处可能存在不合适展示的内容,页面不予展示。您可通过相关编辑功能自查并修改。
如您确认内容无涉及 不当用语 / 纯广告导流 / 暴力 / 低俗色情 / 侵权 / 盗版 / 虚假 / 无价值内容或违法国家有关法律法规的内容,可点击提交进行申诉,我们将尽快为您处理。