Форум программистов, компьютерный форум, киберфорум
C/C++: WinAPI
Войти
Регистрация
Восстановить пароль
Блоги Сообщество Поиск Заказать работу  
 
Рейтинг 4.63/8: Рейтинг темы: голосов - 8, средняя оценка - 4.63
alf19

Надежный перенос файлов (win32api, win2000+)

05.07.2009, 10:52. Показов 1624. Ответов 4
Метки нет (Все метки)

Студворк — интернет-сервис помощи студентам
Требуется помощь в организации надежного переноса файлов (win200+). Файлы могут быть большие и маленькие, как внутри одной файловой системы так и между разными, быть уже сформированными либо формироваться неизвестными способами (в т.ч. через множество открытия-закрытия файла) еще в процессе попытки переноса (в последнем случае должна генерироваться ошибка). Файловые системы и сетевые ресурсы - различные (fat32, ntfs, микрософтовская шара, сетевой ресурс Novell Netware (традиционная ФС, nss))
Хочется вцепиться в файл и гарантированно перенести его. Если файл еще в процессе формирования и просто формирующая его программа закрыла его на микросекунду - это проблемы этой программы. Ну и чтобы не получилось что этот файл открыт кем-то для чтения и поэтому неможет быть удален/перенесен (в этом случае должна (очень желательно) выдаваться ошибка без бесполезной передачи данных на другую ФС/сетевой ресурс)
Пробовал использовать MoveFileEx, но к сожалению он копирует файлы которые в данный момент даже еще записываются. В результате на выходе получаем не реальный файл, а оргызок от него.
Если файл просто открыт кем-либо для чтения - емнип тоже пытается переносить. Если открывать файл эсклюзивно , то афаик потом можно только заниматься копированием вручную, но тут ожидает еще 2 проблемы:
1) если файл переносится внутри одной ФС/сетевого ресурса используя копирование "вручную" с последующим удалением оригинала то потребуется дополнтельное место в каталоге назначения, которого может не оказаться. MoveFileEX же в этом случае просто перенесет файл из одного каталога в другой и все будет с точки зрения свободного места и загрузки оборудования/сети красиво.
2) самая главная проблема: вопрос удаления исходного файла после попытки копирования. Как я понимаю, перед тем как удалить файл - нужно его закрыть. Вот тут возникает вопрос "а не успеет ли какая-то другая программа изменить этот файл между его копированием и удалением?".
Programming
Эксперт
39485 / 9562 / 3019
Регистрация: 12.04.2006
Сообщений: 41,671
Блог
05.07.2009, 10:52
Ответы с готовыми решениями:

Надежный хостинг с очень длительным хранением файлов
недавно я столкнулся с такой проблемой.. хотел разместить код формы в одном сообщении здесь не вышло, из за ограничения по объёму...

Преобразование файлов и перенос их в папки(названия папок содержится в именах файлов)
Доброй ночи! Тяжело быть глупой, помогите автоматизировать (пишу полную задачу, но если это слишком губасто, то важнее та часть кода,...

Создание папок по цифровому названию файлов и перенос этих файлов в созданные папки
Доброго времени суток. Необходим БАТ файл. Что имеем: Общую папку с файлами типа (A0010061609.DBF, A0010061609.PRN, A0010061609.SB,...

4
MCSD: APP BUILDER
 Аватар для IT_Exp
8795 / 1074 / 104
Регистрация: 17.06.2006
Сообщений: 32,602
05.07.2009, 11:47
Читать про Transactional NTFS, Kernel Transaction Manager вообще, и MoveFileTransacted в частности.
Доступно, начиная с Windows Vista
0
Эксперт С++
 Аватар для odip
7176 / 3234 / 82
Регистрация: 17.06.2009
Сообщений: 14,164
05.07.2009, 13:39
А полностью задачу можно ?
Для чего собственно требуется перенос файлов ?
0
2838 / 1647 / 254
Регистрация: 03.12.2007
Сообщений: 4,222
05.07.2009, 23:20
2) Для удаления после закрытия в CreateFile есть FILE_FLAG_DELETE_ON_CLOSE.
Если файл уже открыт на чтение, он вроде нормально переименовывается, если при этом переносится на другой диск, то создаётся копия, а исходный файл удаляется сразу же, как его закрывают. В чём тогда проблема с открытыми на чтение?
0
alf19
08.07.2009, 22:37
Цитата Сообщение от Rififi Посмотреть сообщение
Читать про Transactional NTFS, Kernel Transaction Manager вообще, и MoveFileTransacted в частности.
Доступно, начиная с Windows Vista
увы, нужно начиная с win2000+, до висты еще не доросли (программа с не-гарантированым перемещением работает в том числе на корчах вроде второго пня с 64МБ памяти). и еще вопрос как оно будет на сетевых ресурсах Novell netware работать. Подозреваю что никак.
А полностью задачу можно ?
Для чего собственно требуется перенос файлов ?
забирать файлы, сформированные иным ПО (неподконтрольным в плане ТЗ и доступный только как бинарники) для автоматической отправки "адресату" в исполнении "софт ложит/формирует на сеть файлы для отправки, а дальше почтовый сервер "забирает" это добро и отправляет своими средствами. "Адресат" может быть каталогом на этом/другом сервере, а также - вообще в другой географической области (вопрос обработки почты не стоит). Как повелось - "интерфейс" обмена данными этими программами - на уровне файлов. Т.е. нет никакой центральной БД куда бы оно транзакциями писалось, отправка иными методами силами этих софтин полностью исключена. Более того, там даже не обязательно будет поднят стек TCP/IP.

2) Для удаления после закрытия в CreateFile есть FILE_FLAG_DELETE_ON_CLOSE.
Если файл уже открыт на чтение, он вроде нормально переименовывается, если при этом переносится на другой диск, то создаётся копия, а исходный файл удаляется сразу же, как его закрывают. В чём тогда проблема с открытыми на чтение?
ммм.... Может я и не прав, но прочитав описание в msdn я понял что если попытка копирования перед закрытием файла не удалась по какой-либо причине - то исходный файл будет удален в любом случае? Если посмотреть на ReOpenFile, то она появилась в 2003/vista, что несколько не удовлетворяет исходным требованиям. Хотя вариант заслуживает внимания. Но все же тут возникнет вопрос по п.№1 (доп. место+тормоза+еще некоторые связанные с расширенными аттрибутами на нетвари (Owner/Modifier ЕМНИП поменяются что иногда нежелательно)).

Пока что я склонялся к мысли что сделать так как я хочу - невозможно, и поэтому сводить решение в административно-техническое русло в виде "все формирования - в других каталогах, только после формирования переносим в каталог "отправки", а "оправляющая" программа перед попыткой переноса будет пробовать открыть файл эксклюзивно(и сразу закрыть). если откроется - обрабатываем, если не получится - значит файл еще переносится/копируется и записан не полностью. ничего не делаем, обработаем позже".
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
inter-admin
Эксперт
29715 / 6470 / 2152
Регистрация: 06.03.2009
Сообщений: 28,500
Блог
08.07.2009, 22:37
Помогаю со студенческими работами здесь

Поиск новейших версий файлов из одноимённых файлов, находящихся в двух каталогах, и перенос найденных в третий
Здравствуйте. Возникла необходимость в создании кода на batch, который делает следующее. Сначала код проверяет главную папку, содержащую...

Перенос файлов
Добрый день. Помогите новичку в этом нелегком деле. Есть папка в которую сыпятся файлы, иногда txt, иногда xml, иногда jpeg, иногда pdf....

Перенос файлов
хочу переустановить систему полностью (с нуля), но меня останавливает одно, как бы странно это не звучало, но у меня есть важные файлы,...

Перенос файлов
Помогите с кодом переноса файлов (*.rft, *.1ls) после завершения работы с формой. Вот код который есть у меня для одного типа файлов. ...

Перенос файлов
Всем привет, у меня такой вопрос, каким образом можно с одного сервера переносить все файлы на другой не скачивая их себе на комп? на...


Искать еще темы с ответами

Или воспользуйтесь поиском по форуму:
5
Ответ Создать тему
Новые блоги и статьи
Использование SDL3-callbacks вместо функции main() на Android, Desktop и WebAssembly
8Observer8 24.01.2026
Если вы откроете примеры для начинающих на официальном репозитории SDL3 в папке: examples, то вы увидите, что все примеры используют следующие четыре обязательные функции, а привычная функция main(). . .
моя боль
iceja 24.01.2026
Выложила интерполяцию кубическими сплайнами www. iceja. net REST сервисы временно не работают, только через Web. Написала за 56 рабочих часов этот сайт с нуля. При помощи perplexity. ai PRO , при. . .
Модель сукцессии микоризы
anaschu 24.01.2026
Решили писать научную статью с неким РОманом
http://iceja.net/ математические сервисы
iceja 20.01.2026
Обновила свой сайт http:/ / iceja. net/ , приделала Fast Fourier Transform экстраполяцию сигналов. Однако предсказывает далеко не каждый сигнал (см ограничения http:/ / iceja. net/ fourier/ docs ). Также. . .
http://iceja.net/ сервер решения полиномов
iceja 18.01.2026
Выкатила http:/ / iceja. net/ сервер решения полиномов (находит действительные корни полиномов методом Штурма). На сайте документация по API, но скажу прямо VPS слабенький и 200 000 полиномов. . .
Расчёт переходных процессов в цепи постоянного тока
igorrr37 16.01.2026
/ * Дана цепь(не выше 3-го порядка) постоянного тока с элементами R, L, C, k(ключ), U, E, J. Программа находит переходные токи и напряжения на элементах схемы классическим методом(1 и 2 з-ны. . .
Восстановить юзерскрипты Greasemonkey из бэкапа браузера
damix 15.01.2026
Если восстановить из бэкапа профиль Firefox после переустановки винды, то список юзерскриптов в Greasemonkey будет пустым. Но восстановить их можно так. Для этого понадобится консольная утилита. . .
Сукцессия микоризы: основная теория в виде двух уравнений.
anaschu 11.01.2026
https:/ / rutube. ru/ video/ 7a537f578d808e67a3c6fd818a44a5c4/
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2026, CyberForum.ru