Многопоточность и доступ к файлам

progua

Client
Регистрация
01.01.2012
Сообщения
186
Благодарностей
8
Баллы
18
Здравствуйте.
Я написал несколько десятков шаблонов. Их суть такова: каждый шаблон заходит в папку на компе, берет одну статью из файла и публикует на определенный сайт.
Брать статью с удалением я не могу, так как публикация может быть неудачной и жалко терять статью. Поэтому, я сначала ее беру, а потом перемещаю в другую папку (например temp). Потом, если публикация удачная, то статью из папки temp удаляю. Вроде тестил, все работает норм, но меня терзает один вопрос:
Если я одновременно запущу 15 шаблонов, может ли быть такое, что два шаблона одновременно обратятся к одной статье?
То есть, я беру статью и сразу следующим экшеном ее перемещаю в другую папку. Вроде доля секунды, но все же.
 

doc

Client
Регистрация
30.03.2012
Сообщения
8 685
Благодарностей
4 641
Баллы
113

progua

Client
Регистрация
01.01.2012
Сообщения
186
Благодарностей
8
Баллы
18

doc

Client
Регистрация
30.03.2012
Сообщения
8 685
Благодарностей
4 641
Баллы
113
Пути к статьям в список. Брать построчно пути со списка с удалением.
Можно реализовать выбор статьи и её перемещение в temp через код и залочить его.
Можно попробовать прописывать выбранную статьи в глобальную переменную. А между выбором и записью в эту переменную поставить проверку, которая будет смотреть, нет ли такой статьи уже в этой глобальной переменной. Но тут, вроде как тоже есть лазейка, в которой могут потоки столкнуться.

Но это так, теория. Подобного рода микромоменты мне не просто даются
 
  • Спасибо
Реакции: progua

doc

Client
Регистрация
30.03.2012
Сообщения
8 685
Благодарностей
4 641
Баллы
113
Здравствуйте.
Я написал несколько десятков шаблонов. Их суть такова: каждый шаблон заходит в папку на компе, берет одну статью из файла и публикует на определенный сайт.
Брать статью с удалением я не могу, так как публикация может быть неудачной и жалко терять статью. Поэтому, я сначала ее беру, а потом перемещаю в другую папку (например temp). Потом, если публикация удачная, то статью из папки temp удаляю. Вроде тестил, все работает норм, но меня терзает один вопрос:
Если я одновременно запущу 15 шаблонов, может ли быть такое, что два шаблона одновременно обратятся к одной статье?
То есть, я беру статью и сразу следующим экшеном ее перемещаю в другую папку. Вроде доля секунды, но все же.
А вообще, если так подумать, даже если несколько потоков обратятся к одной статье, только один сможет её перенести. И только он будет с ней работать. Остальные посыпятся на перемещении. Может не красиво, но не критично. Общая последовательность запланированной работы нарушена не будет
 
  • Спасибо
Реакции: progua

amyboose

Client
Регистрация
21.04.2016
Сообщения
2 312
Благодарностей
1 191
Баллы
113
В данном вопросе надо использовать класс mutex. Он позволяет создавать объект блокировки на уровне системы (в отличие от класса lock, который создает её на базе одного процесса) таким образом, что любое приложение, обращающееся к данному системному объекту блокировки класса mutex (в нашем случае в код внедряется работа с файлом) будет ждать того момента, пока другой поток не закончит с ним работу (подробнее на msdn ищите).
P.S. разработчикам зенки тоже не мешало бы его реализовать.
P.S.S. также есть реализации чтения файла в многопоточности без каких-либо проблем при работе с ReaderWriterLockSlim, но запись там в 1 поток может идти.
 
Последнее редактирование:

Кто просматривает тему: (Всего: 1, Пользователи: 0, Гости: 1)