嵌入式开发正确打开串口打印日志的方法

本文介绍了嵌入式开发中通过串口进行日志打印的方法,强调了日志打印对于调试的重要性。文章详细讲解了VA_LIST的使用步骤,包括VA_START、VA_ARG和VA_END宏的含义,并给出了一个示例函数`gsm_serial_log`,该函数利用这些宏处理可变参数,以格式化的方式输出日志。同时,文章提供了`GSM_LOG`宏以简化日志调用。
摘要由CSDN通过智能技术生成

        开发中常用串口打印日志,用串口日志打印可以提高解决bug的效率,可以区分不同模块的日志,打印数据前需要指明信息来源(可自定义),方便使用,最好像printf。

知识点总结:

1.VA_LIST用法,可以是传入一个参数也可以是多个
        (1)在函数里定义一具VA_LIST型的变量,变量指向参数的指针;
        (2)用VA_START宏初始化变量刚定义的VA_LIST变量;
        (3)用VA_ARG返回可变的参数,VA_ARG的第二个参数是你要返回的参数的类型                        (如 果函数有多个可变参数的,依次调用VA_ARG获取各个参数);
        (4)最后用VA_END宏结束可变参数的获取

2. __VA_ARGS__   

       表示可变参数列表

3.例程

#define  LOG_BUFF_SIZE      2048

uint32_t gsm_serial_log(const char *fmt,...)

{

    uint32_t log_size;

    va_list ap;

    cur_time tim = {0};

   

    char buff[LOG_BUFF_SIZE] ={0};    

    if(!is_gsm

评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值