Судя по всему, я не могу перемещать файлы на разные тома с помощью Directory.Move.
Я прочитал, что мне нужно скопировать каждый файл по отдельности в место назначения, а затем удалить исходный каталог.
Есть ли у меня другой вариант?





Независимо от того, выполняет ли Directory.Move (или любая другая функция) перемещение между томами, по сути, он в любом случае будет выполнять копирование и удаление. Так что, если вы хотите увеличить скорость, этого не произойдет. Я думаю, что лучшим решением было бы написать свою собственную многоразовую функцию перемещения, которая будет получать метку тома (C:, D :) от путей к и от, а затем либо выполнять перемещение, либо копировать + удалять, когда это необходимо.
Насколько мне известно, другого способа нет, однако при удалении каталога есть загвоздка: файлы, доступные только для чтения, могут вызвать исключение UnauthorizedAccessException при удалении каталога и всего его содержимого.
public void removeReadOnlyDeep(string directory)
{
string[] files = Directory.GetFiles(directory);
foreach (string file in files)
{
FileAttributes attributes = File.GetAttributes(file);
if ((attributes & FileAttributes.ReadOnly) != 0)
{
File.SetAttributes(file, ~FileAttributes.ReadOnly);
}
}
string[] dirs = Directory.GetDirectories(directory);
foreach (string dir in dirs)
{
removeReadOnlyDeep(dir);
}
}
это рекурсивно выполняет каталог и снимает все флаги только для чтения. Звоните перед тем, как удалить справочник :)
Более простой вариант - добавить ссылку на пространство имен Microsoft.VisualBasic и использовать метод MoveDirectory, который может перемещаться между томами.
Microsoft.VisualBasic.FileIO.FileSystem.MoveDirectory(sourceDirName, destDirName);
Попробуйте использовать это:
public static void RobustMove(string sourceDirectory, string destDirectory)
{
//move if directories are on the same volume
if (Path.GetPathRoot(source) == Path.GetPathRoot(destination))
{
Directory.Move(source, destination);
}
else
{
CopyDirectoryRecursive(source, destination);
Directory.Delete(source, true);
}
}
Вы найдете функцию CopyDirectoryRecursive здесь:
Это должно работать, пока вы не используете составной объем или символьные ссылки на другой физический диск.
Чтобы быть еще более надежным, вы можете улучшить эту функцию, чтобы использовать Move до тех пор, пока не будет выбрано System.IO .Exception, а затем переключиться на копирование и удаление.