Форум программистов «Весельчак У»
  *
Добро пожаловать, Гость. Пожалуйста, войдите или зарегистрируйтесь.
Вам не пришло письмо с кодом активации?

  • Рекомендуем проверить настройки временной зоны в вашем профиле (страница "Внешний вид форума", пункт "Часовой пояс:").
  • У нас больше нет рассылок. Если вам приходят письма от наших бывших рассылок mail.ru и subscribe.ru, то знайте, что это не мы рассылаем.
   Начало  
Наши сайты
Помощь Поиск Календарь Почта Войти Регистрация  
 
Страниц: [1]   Вниз
  Печать  
Автор Тема: Что бывает при частом открытии и закрытии файла  (Прочитано 6939 раз)
0 Пользователей и 1 Гость смотрят эту тему.
Daniloff
Помогающий

ru
Offline Offline

« : 17-12-2006 14:47 » 

Думаю, сей факт кому-нибудь пригодится.
Сделал hook для перехвата стандартных функций API, и моя программа открывает текстовый файл, позиционирует указатель на конец файла и пишет туда строку (ведет лог). Поскольку одновременно в памяти может находиться несколько процессов, использующих контролируемую функцию, каждый раз приходится закрывать файл и открывать его снова. Оказалось, что такое решение очень сильно расходует системные ресурсы. Когда файл лога небольшой - все нормально, а когда он подходит к мегабайту - начинаются тормоза. Плюс антивирус свою толику добавляет - каждый раз проверяет открываемый файл. А циклов открытие-запись-закрытие может быть несколько десятков в секунду!
В результате task manager показывает 100%-ную загруженность процессора системой.
(Файловая система, судя по всему, позиционирует на конец файла не мгновенно!)
Записан
Алексей++
глобальный и пушистый
Глобальный модератор

ru
Offline Offline
Сообщений: 13


« Ответ #1 : 17-12-2006 16:31 » 

Daniloff, дык... храни и обрабатывай файл в памяти и сохраняй не чаще , скажем, раза в 1 с )
Записан

Антон (LogRus)
Глобальный модератор

ru
Offline Offline
Пол: Мужской
Внимание! Люблю сахар в кубиках!


WWW
« Ответ #2 : 18-12-2006 10:14 » 

Daniloff, нажо было функцию записи в файл защитить объектом синхронизации. Улыбаюсь
Или используй сторонние библиотеки на вроде LogForCPP.

Кстати попробуй ты проделать этот фокус на Linux ты бы имел все шансы получить не файл, а мусор, т.к. в Linux нельзя монопольно открыть файл на запись.
Записан

Странно всё это....
npak
Команда клуба

ru
Offline Offline
Пол: Мужской

« Ответ #3 : 18-12-2006 12:42 » 

Что делать - разработчики файловой системы всегда рассчитывают на более-менее средний случай.  А в среднем один файл открывается/закрывается не очень быстро.

Кстати, Винда в этом не одинока. Мы на Линуксе столкнулись с аналогичной проблемой - наш генератор тестов в своей начальной версии в секунду выдавал несколько сотен тестов. Каждый тест - небольшой файл. Получался аналогичный цикл "создать файл - записать сотню байт - закрыть файл".  Подавляющая доля CPU расходовалась на файловый ввод-вывод.
Записан

UniTesK -- индустриальная технология надежного тестирования.

http://www.unitesk.com/ru/
Daniloff
Помогающий

ru
Offline Offline

« Ответ #4 : 18-12-2006 12:47 » 

оказалось, все-таки зачительная доля тормозов - вина антивируса. Без него практически не виснет.
Сейчас делаю сервис, которому данные для протоколирования будут передаваться через канал.
Записан
Страниц: [1]   Вверх
  Печать  
 

Powered by SMF 1.1.21 | SMF © 2015, Simple Machines