打印
[STM32L1]

printf输出异常

[复制链接]
1189|20
手机看帖
扫描二维码
随时随地手机跟帖
跳转到指定楼层
楼主
supernan|  楼主 | 2019-3-26 19:13 | 只看该作者 回帖奖励 |倒序浏览 |阅读模式
uint8_t ReceData_Handle(void)
{
uint8_t rret = 0;
        frame_head_data *p;
        p = (frame_head_data *) Real_Data;
        printf("%x\r\n",p->cmd);
        printf("%x\r\n",Real_Data[19]);
        //while(1);
        if(p->cmd != CMD_REPEAT)     
        {

                System_param.date_time[0] = Real_Data[11];
                System_param.date_time[1] = Real_Data[12];
                System_param.date_time[2] = Real_Data[13];
                System_param.date_time[3] = Real_Data[14];
                System_param.date_time[4] = Real_Data[15];
                System_param.date_time[5] = Real_Data[16];
                ChangeTime = 1;
                if(Real_Data[19] == 0x00)
                {
                        rret = 0;
                        printf("\r\n工作正常\r\n");
                        
                }
        }
        else
        {
                rret = 0;
                printf("%x\r\n",rret);
               
        }
以上满足这个else if( p->cmd == CMD_REPORTCONFIG)分支时候,为什么打印输出不是0,而是长整形的数据0x200000ab?

使用特权

评论回复
沙发
juventus9554| | 2019-3-26 19:14 | 只看该作者
前面的打印正常么

使用特权

评论回复
板凳
yinxiangh| | 2019-3-26 19:16 | 只看该作者
目测内存空间已经被破坏了

使用特权

评论回复
地板
supernan|  楼主 | 2019-3-26 19:18 | 只看该作者
前面的打印正常呀

使用特权

评论回复
5
xxrs| | 2019-3-26 19:19 | 只看该作者
我比较在意那个Real_Data数组多大

使用特权

评论回复
6
morrisk| | 2019-3-26 19:20 | 只看该作者
  else if( p->cmd == CMD_REPORTCONFIG)
        {
                rret = 0;
                printf("%x\r\n",rret);
               
        }

中的 printf("%x\r\n",rret);  改成 printf("%d\r\n",rret);   你这个打印的是整型数据 而不是字符串(从结果上看,应该是把rret在RAM里面的地址打印出来了)

使用特权

评论回复
7
supernan|  楼主 | 2019-3-26 19:21 | 只看该作者
uint8_t Real_Data[64];  

使用特权

评论回复
8
gongche| | 2019-3-26 19:22 | 只看该作者

目测 rret 没有用到,你直接往外输出‘0’就好了

使用特权

评论回复
9
bqyj| | 2019-3-26 19:23 | 只看该作者

if()
else if() 貌似用得不对,后面的代码(else if里面的)永远都不会运行

使用特权

评论回复
10
supernan|  楼主 | 2019-3-26 19:24 | 只看该作者
就是打印整形数据呀

使用特权

评论回复
11
supernan|  楼主 | 2019-3-26 19:25 | 只看该作者
就是打印整形不是字符串呢

使用特权

评论回复
12
songqian17| | 2019-3-26 19:26 | 只看该作者

数组没溢出
就再查查野指针吧...

使用特权

评论回复
13
zyf部长| | 2019-3-26 19:28 | 只看该作者
printf("%x\r\n",rret);  改成 printf("%d\r\n",rret);

使用特权

评论回复
14
supernan|  楼主 | 2019-3-26 19:29 | 只看该作者
这是改动后的,改之前有运行到出的问题

使用特权

评论回复
15
supernan|  楼主 | 2019-3-26 19:30 | 只看该作者

printf("%x\r\n",rret);  改成 printf("%d\r\n",rret);
其实这2个打印没什么区别。只是16进制整形和十进制整形的差别,应该不是你说的问题

使用特权

评论回复
16
juventus9554| | 2019-3-26 19:32 | 只看该作者
printf("%x\r\n",rret);  改成 printf("%02x\r\n",(UINT16)rret);

使用特权

评论回复
17
dingy| | 2019-3-26 19:33 | 只看该作者
强制转换的问题,在KEIL里面很正常。

使用特权

评论回复
18
zyf部长| | 2019-3-26 19:33 | 只看该作者
你打印的格式不对,改成%d就行了

使用特权

评论回复
19
pengf| | 2019-3-26 19:35 | 只看该作者
你直接输出0,比这个要好,有时间研究这个,还不如去做些有意义的事情

使用特权

评论回复
20
houcs| | 2019-3-26 19:36 | 只看该作者
串口能打印出来什么?

使用特权

评论回复
发新帖 我要提问
您需要登录后才可以回帖 登录 | 注册

本版积分规则

730

主题

10412

帖子

6

粉丝