打印
[STM32L1]

帮我看看printf输出异常

[复制链接]
2014|21
手机看帖
扫描二维码
随时随地手机跟帖
跳转到指定楼层
楼主
nuc990|  楼主 | 2017-9-29 18:14 | 只看该作者 回帖奖励 |倒序浏览 |阅读模式
本帖最后由 nuc990 于 2017-9-30 11:51 编辑
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?
沙发
gujiamao12345| | 2017-9-29 18:17 | 只看该作者
前面的打印正常么
目测内存空间已经被破坏了

使用特权

评论回复
板凳
nuc990|  楼主 | 2017-9-29 20:23 | 只看该作者
gujiamao12345 发表于 2017-9-29 18:17
前面的打印正常么
目测内存空间已经被破坏了

前面的打印正常呀

使用特权

评论回复
地板
gujiamao12345| | 2017-9-30 09:00 | 只看该作者
nuc990 发表于 2017-9-29 20:23
前面的打印正常呀

我比较在意那个Real_Data数组多大

使用特权

评论回复
5
feelhyq| | 2017-9-30 09:21 | 只看该作者
本帖最后由 feelhyq 于 2017-9-30 09:37 编辑

        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里面的地址打印出来了)

使用特权

评论回复
6
nuc990|  楼主 | 2017-9-30 10:48 | 只看该作者
gujiamao12345 发表于 2017-9-30 09:00
我比较在意那个Real_Data数组多大

uint8_t Real_Data[64];  

使用特权

评论回复
7
kingkits| | 2017-9-30 10:51 | 只看该作者
目测 rret 没有用到,你直接往外输出‘0’就好了

使用特权

评论回复
8
kingkits| | 2017-9-30 10:56 | 只看该作者
if()
else if() 貌似用得不对,后面的代码(else if里面的)永远都不会运行

使用特权

评论回复
9
nuc990|  楼主 | 2017-9-30 11:04 | 只看该作者
feelhyq 发表于 2017-9-30 09:21
else if( p->cmd == CMD_REPORTCONFIG)
        {
                rret = 0;

就是打印整形数据呀

使用特权

评论回复
10
nuc990|  楼主 | 2017-9-30 11:05 | 只看该作者
feelhyq 发表于 2017-9-30 09:21
else if( p->cmd == CMD_REPORTCONFIG)
        {
                rret = 0;

就是打印整形不是字符串呢

使用特权

评论回复
11
gujiamao12345| | 2017-9-30 11:26 | 只看该作者
nuc990 发表于 2017-9-30 10:48
uint8_t Real_Data[64];

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

使用特权

评论回复
12
feelhyq| | 2017-9-30 11:34 | 只看该作者
nuc990 发表于 2017-9-30 11:04
就是打印整形数据呀

printf("%x\r\n",rret);  改成 printf("%d\r\n",rret);   用心看回复,答案都在我之前的回复里面

使用特权

评论回复
13
nuc990|  楼主 | 2017-9-30 11:50 | 只看该作者
kingkits 发表于 2017-9-30 10:56
if()
else if() 貌似用得不对,后面的代码(else if里面的)永远都不会运行

没事,先不关心这个

使用特权

评论回复
14
nuc990|  楼主 | 2017-9-30 11:51 | 只看该作者
kingkits 发表于 2017-9-30 10:51
目测 rret 没有用到,你直接往外输出‘0’就好了

这是改动后的,改之前有运行到出的问题

使用特权

评论回复
15
nuc990|  楼主 | 2017-9-30 11:53 | 只看该作者
feelhyq 发表于 2017-9-30 11:34
printf("%x\r\n",rret);  改成 printf("%d\r\n",rret);   用心看回复,答案都在我之前的回复里面 ...

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

使用特权

评论回复
16
hcn001| | 2017-9-30 14:12 | 只看该作者
printf("%x\r\n",rret);  改成 printf("%02x\r\n",(UINT16)rret);

使用特权

评论回复
17
hcn001| | 2017-9-30 14:13 | 只看该作者
强制转换的问题,在KEIL里面很正常。

使用特权

评论回复
18
IICeeprom| | 2017-9-30 14:52 | 只看该作者
你打印的格式不对,改成%d就行了

使用特权

评论回复
19
kingkits| | 2017-9-30 17:33 | 只看该作者
你直接输出0,比这个要好,有时间研究这个,还不如去做些有意义的事情

使用特权

评论回复
20
山东电子小菜鸟| | 2017-9-30 19:03 | 只看该作者
怎么可看不到你的代码 楼上的怎吗看到的

使用特权

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

本版积分规则

107

主题

217

帖子

0

粉丝