Моя программа считает трафик и соответственно деньги. Данные хранятся в файлах. Но иногда в файл записывается какоето левое значение. Вот кусок кода:
if (open_file(str, "r") == 0){
fscanf(stream, "%f", &t_data[a].access_bonus);
}else{
t_data[a].access_bonus = 0;
}
fclose(stream);
syslog(LOG_INFO,"Read access_bonus for user %s = %f",t_data[a].login, t_data[a].access_bonus);
f_tmp = t_data[a].payment_traf;
t_data[a].access_bonus += (f_tmp * t_data[a].price);
syslog(LOG_INFO,"Write access_bonus for user %s = %f",t_data[a].login, t_data[a].access_bonus);
syslog(LOG_INFO,"Write payment_traf for user %s = %f",t_data[a].login, f_tmp);
syslog(LOG_INFO,"Write price for user %s = %f",t_data[a].login, (f_tmp * t_data[a].price));
if (open_file(str, "w") == 0){
syslog(LOG_INFO,"1 - Write access_bonus for user %s = %f",t_data[a].login, t_data[a].access_bonus);
if (t_data[a].access_bonus >= 0){
syslog(LOG_INFO,"2.1 - Write access_bonus for user %s = %f",t_data[a].login, t_data[a].access_bonus);
fprintf(stream, "%.2f", t_data[a].access_bonus);
syslog(LOG_INFO,"3.2 - Write access_bonus for user %s = %f",t_data[a].login, t_data[a].access_bonus);
}else{
syslog(LOG_INFO,"2.2 - Write access_bonus for user %s = %f",t_data[a].login, t_data[a].access_bonus);
fprintf(stream, "%.2f", 0);
syslog(LOG_INFO,"3.2 - Write access_bonus for user %s = %f",t_data[a].login, t_data[a].access_bonus);
}
}
fclose(stream);
syslog(LOG_INFO,"4 - Write access_bonus for user %s = %f",t_data[a].login, t_data[a].access_bonus);
if (open_file(str, "r") == 0){
fscanf(stream, "%f", &f_tmp);
}else{
f_tmp = 0;
}
fclose(stream);
syslog(LOG_INFO,"Read after write access_bonus for user %s = %f",t_data[a].login, f_tmp);
А вот что происходит(из лога):
Read access_bonus for user zloydrug = 0.000000
Write access_bonus for user zloydrug = -0.300000
Write payment_traf for user zloydrug = -1.000000
Write price for user zloydrug = -0.300000
1 - Write access_bonus for user zloydrug = -0.300000
2.2 - Write access_bonus for user zloydrug = -0.300000
3.2 - Write access_bonus for user zloydrug = -0.300000
4 - Write access_bonus for user zloydrug = -0.300000
Read after write access_bonus for user zloydrug = 72.349998
Как видно расчёт происходит правильно, и в файл записуется 0. Но после записи уже читается число 72.
Почему? Я понять пока немогу.
Причём происходит это не всегда а изредка.
Что делать? подскажите!
Спасибо!