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

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;
                }
        }
       
}

友情提示: 此问题已得到解决,问题已经关闭,关闭后问题禁止继续编辑,回答。