Случайный файл C #, используемый другими ошибками процесса - PullRequest
1 голос
/ 13 августа 2011

Я написал приложение, которое принимает несжатый WAV-файл и кодирует его в FLA-файл, MP3-файл и AAC-файл. Flac и mp3 работают нормально, но при выполнении кодирования aac (с использованием Nero AAC encoder ) I в случайном порядке получают IOExceptions в отношении используемого файла. Иногда - но не так часто - это происходит во время генерации файла - Как может файл, созданный моим процессом, использоваться другим? Но чаще всего, когда я пишу метатеги с помощью TagLib, я получаю ошибки. Поэтому я установил код для запуска handle_sysinternal's handle.exe в рассматриваемом файле при ошибке ввода-вывода, но он возвращает тот факт, что в файле нет дескрипторов. Это врожденная проблема с кодировщиком Nero AAC?

try
{
if ( ! Directory.Exists( es.dest ) )
    {
        Directory.CreateDirectory( Path.GetDirectoryName( es.dest ) );
    }
    if ( File.Exists( es.dest ) ) { File.Delete( es.dest ); }
    bool CommandGenerated = enc.GenerateCommandLine();

    string procOutput = String.Empty;
    if ( CommandGenerated )
    {
        Console.Out.WriteLine( "Starting:" );
        p = new Process();
        p.StartInfo.WorkingDirectory = Path.GetDirectoryName( current_config_exe );
        p.StartInfo.FileName = current_config_exe;
        p.StartInfo.Arguments = enc.ToString();
        p.StartInfo.UseShellExecute = false;
        p.StartInfo.RedirectStandardOutput = true;
        p.Start();

        procOutput = p.StandardOutput.ReadToEnd();
        p.WaitForExit();
        int exit_code = p.ExitCode;
        p.Close();
        p.Dispose();
        string exit_msg = "Encoder exitcode: " + exit_code + "\n";
        if ( exit_code != 0 )
        {
            Console.WriteLine( "There was a problem. Do you want to continue? (y/n) (Default = y)" );
            string response = Console.ReadLine();
            if ( response.ToLower() == "n" )
            {
                throw new Exception( "Note: " + exit_msg );
            }
        }
        else if ( es.use_taglib_for_meta && enc.metaswitches != null )
        {
            Meta meta = new Meta( es.dest );
            if ( meta.SetMetaTags( enc.metaswitches, true ) )
            {
                WriteLog( "Meta tags successfully wriiten to: \n" + es.dest, true, false );
            }
            else
            {
                WriteLog( "Meta tags NOT wriiten to: " + es.dest, true );
            }
        }
    }
}
catch ( IOException ex )
    {
        Handler.GetHoldingProcess( es.dest );
        Program.WriteLog( "(writing track to file) Error saving file " + es.dest + ":\n" + ex, true );
        return false;
    }

1 Ответ

1 голос
/ 13 августа 2011

Я бы предложил вам другой инструмент SysInternals - filemon.exe

  1. Поставьте точку останова на метод, который жалуется на IOException
  2. Запустите приложение в режиме отладки изVS
  3. Когда остановка VS на точке останова - запустить filemon.exe
  4. Нажмите F5 в VS (продолжить выполнение)
  5. При возникновении исключения - приостановить filemon.exe и начать анализ того, чтопродолжая работу с файлом

Чтобы упростить исследование, вы можете установить фильтр в filemon по имени файла или процесса Удачи!

...