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

德阳网站优化长沙做企业网站

德阳网站优化,长沙做企业网站,北京网站制作的公司哪家好,网站视频存储方案1.日志的重要性 故障排查与调试:嵌入式系统通常运行在资源有限的环境中,故障排查和调试变得尤为复杂。日志系统可以记录系统在运行过程中的各种操作、状态和事件信息,方便开发人员追踪和定位问题所在。通过分析日志,可以快速找到故…

1.日志的重要性

  1. 故障排查与调试:嵌入式系统通常运行在资源有限的环境中,故障排查和调试变得尤为复杂。日志系统可以记录系统在运行过程中的各种操作、状态和事件信息,方便开发人员追踪和定位问题所在。通过分析日志,可以快速找到故障源,并进行相应的修复和调试。

  2. 系统性能优化:嵌入式系统的资源有限,因此性能优化尤为关键。日志系统可以记录系统运行过程中的性能指标,如任务执行时间、资源利用率等。通过分析这些日志,可以发现系统性能瓶颈,进行性能优化和资源管理,提高系统的响应速度和资源利用效率。

  3. 资源监控与管理:嵌入式系统可能包含多个任务或模块并发运行,而每个任务和模块都可能占用不同的资源。日志系统可以记录各个任务和模块的资源使用情况,如内存分配情况、任务运行状态等。通过分析日志,可以进行资源的动态监控和管理,以确保嵌入式系统的稳定运行。

  4. 安全审计与故障恢复:嵌入式系统在一些关键领域,如工业控制、医疗设备等,安全性和可靠性要求很高。日志系统可以记录系统的操作行为、故障事件、安全事件等,方便进行安全审计和故障恢复。通过分析日志,可以快速发现安全漏洞和故障点,并采取相应的措施进行修复和恢复。

  5. 协助产品迭代和升级:通过收集和分析日志数据,可以了解用户的使用习惯、问题反馈和需求变化。这些信息可以用于产品的迭代和升级,提供更好的用户体验和功能优化。

2.代码设计 

#ifndef _CJ_LOG_H_
#define _CJ_LOG_H_#include <stdbool.h>#define MAX_LOG_QUEUE_CNT 10typedef enum _LogType
{LT_DEBUG   = 0,LT_INFO    = 1,LT_WARNING = 2,LT_ERROR   = 3,
}LogType;typedef struct _CjLog
{unsigned int timestamp;      //时间戳LogType type;                //类别unsigned char para1;         //参数1unsigned char para2;         //参数2unsigned char para3;         //参数3unsigned char para4;         //参数4int checkSum;                //校验和
}CjLog;void clog_Init();
int clog_addlog(CjLog *log);
int clog_getLog(unsigned int startTime, unsigned int endTime, unsigned char *buf);
bool clog_getLog(unsigned int index, unsigned char *buf);
int clog_getCnt();
void clog_clear();#endif
#include "cjlog.h"
#include "freertos/queue.h"/* 创建一个日志队列 */
static QueueHandle_t log_queue;static void clog_write_thread(void)
{uart_event_t event;CjLog receivedLog;int len = 0;printf("clog_write_thread start !\n");while (1){BaseType_t xStatus = xQueueReceive(log_queue, &receivedLog, portMAX_DELAY);if (xStatus == pdPASS) {printf("Get a new log!\n");/* 写日志函数(需校验checkSum) 具体根据实际平台去实现 */if(flash_writeLog(receivedLog) == false)printf("Write log failed!\n");} else {}}return;
}void clog_Init()
{log_queue = xQueueCreate(MAX_LOG_QUEUE_CNT, sizeof(CjLog));/* 创建一个接收线程 */xTaskCreate(clog_write_thread, "log_thread", 2048, NULL, configMAX_PRIORITIES, NULL);
}void clog_addlog(CjLog *log)
{xQueueSend(log_queue, &log, portMAX_DELAY);
}int clog_getLog(unsigned int startTime, unsigned int endTime, unsigned char *buf)
{if(endTime == 0)endTime = 0xffffffff;/* 读取当前日志数量 具体根据实际平台去实现 */const int logCount = readLogCnt();int cnt = 0;//从最新的日志扫描至最旧的for(int i = 0; i < logCount; i++){/* 读取当前日志 也需要根据平台去实现 */CjLog *log = flash_readLog(i);if(log){if(log->timestamp <= endTime && log->timestamp >= startTime){*buf++ = (unsigned char)(log->timestamp >> 24);*buf++ = (unsigned char)(log->timestamp >> 16);*buf++ = (unsigned char)(log->timestamp >> 8);*buf++ = (unsigned char)(log->timestamp);*buf++ = (unsigned char)log->type;*buf++ = log->para1;*buf++ = log->para2;*buf++ = log->para3;*buf++ = log->para4;cnt ++;}else{if(log->timestamp < startTime)   break;}}elsebreak;}return cnt;
}bool clog_getLog(unsigned int index, unsigned char *buf)
{/* 读取当前日志数量 具体根据实际平台去实现 */const int logCount = flash_readLogCnt();if(index > logCount){return false;}/* 读取当前日志 也需要根据平台去实现 */CjLog *log = flash_readLog(index);if(log){*buf++ = (unsigned char)(log->timestamp >> 24);*buf++ = (unsigned char)(log->timestamp >> 16);*buf++ = (unsigned char)(log->timestamp >> 8);*buf++ = (unsigned char)(log->timestamp);*buf++ = (unsigned char)log->type;*buf++ = log->para1;*buf++ = log->para2;*buf++ = log->para3;*buf++ = log->para4;return true;}elsereturn false;}int clog_getCnt()
{/* 读取当前日志数量 具体根据实际平台去实现 */return flash_readLogCnt();
}void clog_clear()
{/* 清空也需要根据平台去实现 */flash_clearAllLog();
}

3.注意事项

1.与flash有关的函数的实现需要与实际情况结合。

2.flash读的时候要进行校验。

3.日志结构体可以根据实际的flash芯片设计大小,字节对齐等。

/* 4字节对齐 这里刚好是 4个 4字节 */
typedef struct _CjLog
{unsigned int timestamp;      //时间戳LogType type;                //类别unsigned char para1;         //参数1unsigned char para2;         //参数2unsigned char para3;         //参数3unsigned char para4;         //参数4int checkSum;                //校验和
}CjLog;

http://www.yayakq.cn/news/381339/

相关文章:

  • Python个人网站建设论文记事本做网站如何排版
  • 货源网站程序网页平面设计是什么
  • 如何制作一个属于自己的网站如何让域名跳转网站
  • 建局域网网站网络推广加盟
  • 建网站花费个人做网站还是公众号赚钱好
  • 网站开发四点注意事项免费软件的源代码公开吗
  • 高职两学一做专题网站网站域名注册信息查询
  • w网站链接如何做脚注佛山市企业网站建设报价
  • 男女做特别污污的事情网站做平面哪个网站的素材最好
  • 摄影网站设计素材上海松江网站设计公司
  • 杭州网站seo推广浙江网商银行
  • 南昌电商网站设计比亚迪电子股票
  • 如何在国外建网站百度网页版登录
  • 企业的网站维护如何将网站提交给谷歌
  • 哪个网站公司做的设计公司网站欣赏
  • 网站建设费税率河北省建设厅网站6
  • 网站信息内容建设管理好的网站建设专业公司
  • 西安网站建设案例做网站推广的难点
  • 闵行区邮编seo运营学校
  • .网站建设课程设计中文网站模板 免费
  • 源码可以做网站吗好听好记的域名
  • php 获取网站根域名找个网站这么难2021
  • php网站模板制作工具苏州市住房和城乡建设局信息网站
  • php mysql网站开发项目式教程建设京东物流网站的目标是什么
  • 河北公司网站建设aspnet网站开发教程
  • 晋城建设网站南京公司做网站
  • 广西建设厅官方网站文件通知wordpress 本地写文章
  • 怎么给网站加代码产品网站别人是如何做优化的
  • 网站的不同类电信网站备案查询系统
  • 比较好网站制作公司自己怎么做短视频网站