The OpenNET Project / Index page

[ новости /+++ | форум | теги | ]



Индекс форумов
Составление сообщения

Исходное сообщение
"Странности при записи в файл"
Отправлено zkrvova, 01-Июн-06 10:57 
Моя программа считает трафик и соответственно деньги. Данные хранятся в файлах. Но иногда в файл записывается какоето левое значение. Вот кусок кода:


            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.
Почему? Я понять пока немогу.

Причём происходит это не всегда а изредка.

Что делать? подскажите!
Спасибо!

 

Ваше сообщение
Имя*:
EMail:
Для отправки новых сообщений в текущей нити на email укажите знак ! перед адресом, например, !user@host.ru (!! - не показывать email).
Более тонкая настройка отправки ответов производится в профиле зарегистрированного участника форума.
Заголовок*:
Сообщение*:
 
При общении не допускается: неуважительное отношение к собеседнику, хамство, унизительное обращение, ненормативная лексика, переход на личности, агрессивное поведение, обесценивание собеседника, провоцирование флейма голословными и заведомо ложными заявлениями. Не отвечайте на сообщения, явно нарушающие правила - удаляются не только сами нарушения, но и все ответы на них. Лог модерирования.



Партнёры:
PostgresPro
Inferno Solutions
Hosting by Hoster.ru
Хостинг:

Закладки на сайте
Проследить за страницей
Created 1996-2024 by Maxim Chirkov
Добавить, Поддержать, Вебмастеру