質問をすることでしか得られない、回答やアドバイスがある。

15分調べてもわからないことは、質問しよう!

新規登録して質問してみよう
ただいま回答率
87.20%
.NET

.NETとは、主に.NET Frameworkと呼ばれるアプリケーションまたは開発環境を指します。CLR(共通言語ランタイム)を搭載し、入力された言語をCIL(共通中間言語)に変換・実行することが可能です。そのため、C#やPythonなど複数の言語を用いることができます。

C#

C#はマルチパラダイムプログラミング言語の1つで、命令形・宣言型・関数型・ジェネリック型・コンポーネント指向・オブジェクティブ指向のプログラミング開発すべてに対応しています。

解決済

Process.StandardOutput.ReadToEnd()関数で処理がフリーズする原因が知りたい。

samidare_chan
samidare_chan

総合スコア142

.NET

.NETとは、主に.NET Frameworkと呼ばれるアプリケーションまたは開発環境を指します。CLR(共通言語ランタイム)を搭載し、入力された言語をCIL(共通中間言語)に変換・実行することが可能です。そのため、C#やPythonなど複数の言語を用いることができます。

C#

C#はマルチパラダイムプログラミング言語の1つで、命令形・宣言型・関数型・ジェネリック型・コンポーネント指向・オブジェクティブ指向のプログラミング開発すべてに対応しています。

1回答

-4評価

0クリップ

364閲覧

投稿2022/05/19 02:32

提示コードですがConverter.csの関数GetFormat(String? url)部のpro.StandardOutput.ReadToEnd();の部分で処理が停止してしまいますこれは何が原因なのでしょうか?

環境

OS: windows10
IDE: Visual studio 2022
フレームワーク: .Net 6.0

確認したこと

MainWindow.csの初期化部ですが先にウインドウフォームの初期化を行ってその後Convert.Init()関数を実行してConverterクラスを初期化してその際にpro.StartInfo.RedirectStandardOutput = true; pro.StartInfo.RedirectStandardError = true;をしてStandardOutput.ReadToEnd();関数を使えるよにしています。Debug.WriteLine()関数(出力画面参照)でInit関数が先に実行されていることを確認しました。Converter.GetFormat()関数をコメントアウトするとウインドウが表示されるためこの関数が原因なのは確実です。

参考サイト:https://atmarkit.itmedia.co.jp/fdotnet/dotnettips/805pipeasync/pipeasync.html
参考サイト(リファレンス): https://docs.microsoft.com/ja-jp/dotnet/api/system.diagnostics.process.standardoutput?view=net-6.0

出力画面
'Downloader.exe' (CoreCLR: DefaultDomain): 'C:\Program Files\dotnet\shared\Microsoft.NETCore.App\6.0.5\System.Private.CoreLib.dll' が読み込まれました。シンボルの読み込みをスキップしました。モジュールは最適化されていて、デバッグ オプションの [マイ コードのみ] 設定が有効になっています。 //文字数の関係で省略 'Downloader.exe' (CoreCLR: clrhost): 'C:\Program Files\dotnet\shared\Microsoft.NETCore.App\6.0.5\System.Diagnostics.Process.dll' が読み込まれました。シンボルの読み込みをスキップしました。モジュールは最適化されていて、デバッグ オプションの [マイ コードのみ] 設定が有効になっています。 Init 'Downloader.exe' (CoreCLR: clrhost): 'C:\Program Files\dotnet\shared\Microsoft.NETCore.App\6.0.5\System.Text.Encoding.Extensions.dll' が読み込まれました。シンボルの読み込みをスキップしました。モジュールは最適化されていて、デバッグ オプションの [マイ コードのみ] 設定が有効になっています。 あああああ プログラム '[11572] Downloader.exe' はコード 4294967295 (0xffffffff) で終了しました。
MainWindow.cs

cs

using System; using System.Collections.Generic; using System.Linq; using System.Text; using System.Threading.Tasks; using System.Diagnostics; using System; using System.IO; namespace Downloader { public partial class MainWindow : Form { public MainWindow() { InitializeComponent(); //ウインドウ初期化 Converter.Init(); //初期化 Format? f = Converter.GetFormat("https://www.youtube.com/watch?v=0O7Wc9OgslY&list=RDzCmdKyNYDTw&index=5"); } } }
Converter.cs

cs

using System; using System.Collections.Generic; using System.Linq; using System.Text; using System.Threading.Tasks; using System.Diagnostics; using System; using System.IO; namespace Downloader { //public static class Function static public class Converter { private static Process pro = new Process(); /* ########################### 初期化 ###########################*/ static public void Init() { Debug.WriteLine("Init"); pro.StartInfo.FileName = "yt-dlp "; pro.StartInfo.RedirectStandardOutput = true; pro.StartInfo.RedirectStandardError = true; pro.StartInfo.CreateNoWindow = true; // コンソール・ウィンドウを開かない pro.StartInfo.UseShellExecute = false; // シェル機能を使用しない } /* ########################### URLからフォーマット取得 ###########################*/ static public Format? GetFormat(String? url) { Format? data = new Format(); pro.StartInfo.Arguments = " -F " + url; //Debug.WriteLine("いい"); pro.Start(); //StreamReader reader = pro.StandardOutput; //string output = reader.ReadToEnd(); //Debug.WriteLine("おおお"); //Debug.WriteLine(output); //pro.WaitForExit(); Debug.WriteLine("あああああ"); string result = pro.StandardOutput.ReadToEnd(); Debug.WriteLine("qqqqq"); if (result == "") { MessageBox.Show("URL ERROR", "", MessageBoxButtons.OK, MessageBoxIcon.Error); return null; } else { Debug.WriteLine("ううう"); /* StringReader sr = new StringReader(result); string? line = sr.ReadLine(); while (line != null) { Debug.WriteLine(line); line = sr.ReadLine(); } sr.Close(); */ } Debug.WriteLine("いい"); return null; } /* ########################### 指定した文字以降を削除 ###########################*/ static public string GetRemoveRight(string str, string removeStr) { int length = str.IndexOf(removeStr); if (length < 0) { return str; } return str.Substring(0, length); } } }

良い質問の評価を上げる

以下のような質問は評価を上げましょう

  • 質問内容が明確
  • 自分も答えを知りたい
  • 質問者以外のユーザにも役立つ

評価が高い質問は、TOPページの「注目」タブのフィードに表示されやすくなります。

気になる質問をクリップする

クリップした質問は、後からいつでもマイページで確認できます。

またクリップした質問に回答があった際、通知やメールを受け取ることができます。

teratailでは下記のような質問を「具体的に困っていることがない質問」、「サイトポリシーに違反する質問」と定義し、推奨していません。

  • プログラミングに関係のない質問
  • やってほしいことだけを記載した丸投げの質問
  • 問題・課題が含まれていない質問
  • 意図的に内容が抹消された質問
  • 過去に投稿した質問と同じ内容の質問
  • 広告と受け取られるような投稿

評価を下げると、トップページの「アクティブ」「注目」タブのフィードに表示されにくくなります。

Zuishin

2022/05/19 02:45

この原因は書いたけど削除したよね。
samidare_chan

2022/05/19 02:47

削除した覚えはないのですが?なんて質問でしょうか?

まだ回答がついていません

会員登録して回答してみよう

15分調べてもわからないことは
teratailで質問しよう!

ただいまの回答率
87.20%

質問をまとめることで
思考を整理して素早く解決

テンプレート機能で
簡単に質問をまとめる

質問する

関連した質問

同じタグがついた質問を見る

.NET

.NETとは、主に.NET Frameworkと呼ばれるアプリケーションまたは開発環境を指します。CLR(共通言語ランタイム)を搭載し、入力された言語をCIL(共通中間言語)に変換・実行することが可能です。そのため、C#やPythonなど複数の言語を用いることができます。

C#

C#はマルチパラダイムプログラミング言語の1つで、命令形・宣言型・関数型・ジェネリック型・コンポーネント指向・オブジェクティブ指向のプログラミング開発すべてに対応しています。