access the file 'file path' because it is being used by another process"
если у меня создается новый файл через AppendAllLines, этот AppendAllLines локается и этот код вызывается только из одного процесса?
lock (locker)
{
File.AppendAllLines(@"C:\Users\user\Desktop\MyData.txt", new[] { "data" });
}
Значит запись не закончился и дескриптор файла удерживается (не успевает закрыться перед следующей записью) Странно, но такое в принципе может произойти при попытке работать с файлами в асинхронных методах и функциях
в проекте async не упоминается ни разу ))) зато полно тредов, но тут же локается.. ну тут 50-60 раз примерно будет вызываться. я тоже так начал подозревать что что -то не закрывается из-за того что слишком много раз вызывается, но блин вопрос почему .net тогда возвращает управление если файл еще не закрылся
а, я нашел)) лок обьект у меня не статический был а на каждый вызов этого кода создавался новый экземпляр
Тут 2 варианта: 1. Либо CreateFile/WriteFile (win32 api) для твоей аппы используется именно для асинхронного обращения к файлу (нужно смотреть в исходники AppendAllLines()) 2. Ос не может передать событие закрытия дескриптора файла в твою аппу для синхронизации записи. В таком случае, для того, чтобы если хэндл не успевает закрыться, разумнее использовать один экземпляр класса. В таком случае внутри, теоретически, будет один дескриптор на все функции IO
Ну вот как раз второй случай
Мне нужно было открыть файл и спрасить его и записать данные в бд и при необходимости наоборот Я юзал два юзинга, один для работы с файлом, второй для бд, и при этом всегда было ок, потому что юзинг работает с IDisposable и освобождает ресурсы. Автоматом вызывая Dispose мне просто так удобней было
Погоняй прогу под procmon — мб поймаешь того, кто открывает этот файл кроме тебя.
Обсуждают сегодня