有点很奇怪的现象,前后读取结构体的值改变了

2019-07-25 11:15发布

其他程序我就不放了,主要就是一个测量脉宽的实验。
一次更新就是1s,arr是10000,下面我打印了一个计数的总值,然后两种换算成秒的方式。
但是换算秒的公式放在前面和后面的值读出来完全不一样,有点懵逼,求高手指点。
int main()
{
        u32 time,time1,time2;
        USART_Config();
        tim1ic_init();
        printf ( " 按下K1,测试K1按下的时间 " );
        while(1)
        {
                if (tim1initstruct.icfinishflag==1)
                {
                        time1=tim1initstruct.icupdate;
            time2=tim1initstruct.icccr;
                        time=tim1initstruct.icupdate*10000+tim1initstruct.icccr;
                        printf("高电平时间为: %.4f s ",(float)(time1)+((float)time2)/10000);  
                        printf("高电平时间为: %d s ",time);
                        printf("高电平时间为: %.4lf s ",(double)(time)/(double)(10000));
                        time=tim1initstruct.icupdate*10000+tim1initstruct.icccr;
                        printf("高电平时间为: %.4lf s ",(double)(time)/(double)(10000));   //很奇怪 后面在读这个数的时候数值变了
                        tim1initstruct.icfinishflag=0;
                }
        }
       
}

友情提示: 此问题已得到解决,问题已经关闭,关闭后问题禁止继续编辑,回答。
该问题目前已经被作者或者管理员关闭, 无法添加新回复
14条回答
正点原子
1楼-- · 2019-07-25 11:34
仿真,看看原始数据是否一致?
aiyeba
2楼-- · 2019-07-25 15:02
你看看你中断里面结构体那俩个变量是不是在自加;
tim1initstuct.icupdate这个变量是全局变量吧,他一直在++
蛋白质khun
3楼-- · 2019-07-25 15:48
 精彩回答 2  元偷偷看……
蛋白质khun
4楼-- · 2019-07-25 17:16
比如 我按下的时间是 0.1419秒,前面三个显示的分别是 0.1419s,1419s,0.1419s,计算公式放到后面 打印出来就变成了0.0000s,但是有的时候值又是正常的,不知道哪里有问题,感觉很奇怪。
蛋白质khun
5楼-- · 2019-07-25 22:34
怎么没有人啊,自己手动刷
蛋白质khun
6楼-- · 2019-07-26 02:26
正点原子 发表于 2017-11-6 01:13
仿真,看看原始数据是否一致?

不好意思,我以为没人回复我了呢,我仿真看了一下,应该是因为更新中断的数值在自加,导致数值不一样,但我还是不太明白,即使数值不一样,不是也应该是大一点吗,为什么有时候会是0

一周热门 更多>