131

非常に単純な WPF テスト アプリケーションから使用Console.WriteLine()していますが、コマンド ラインからアプリケーションを実行すると、コンソールに何も書き込まれていません。ここで何が起こっているのか知っている人はいますか?

VS 2008 で WPF アプリケーションを作成し、Console.WriteLine("text")それが実行される場所に追加するだけで再現できます。何か案は?

私が今必要としているのは、Console.WriteLine(). log4net やその他のロギング ソリューションを使用できることはわかっていますが、このアプリケーションにはそれほど多くの機能は必要ありません。

編集:Console.WriteLine()コンソールアプリケーション用であることを覚えておく必要がありました。まあ、ばかげた質問はありませんよね?:-) 今のところSystem.Diagnostics.Trace.WriteLine()、DebugView だけを使用します。

4

10 に答える 10

181

使用できます

Trace.WriteLine("text");

これは、Visual Studio の [出力] ウィンドウに出力されます (デバッグ時)。

診断アセンブリが含まれていることを確認してください。

using System.Diagnostics;
于 2008-10-02T02:20:35.100 に答える
141

プロジェクトを右クリックし、[プロパティ]、[アプリケーション] タブ、[出力タイプ] を [コンソール アプリケーション] に変更すると、コンソールも表示されます。

于 2008-10-02T02:17:12.097 に答える
96

Console.Write メソッドを実際に呼び出す前に、コンソール ウィンドウを手動で作成する必要があります。これにより、プロジェクトの種類を変更せずにコンソールが適切に機能するようになります (WPF アプリケーションでは機能しません)。

以下は、ConsoleManager クラスがどのように見えるか、およびそれを使用してプロジェクトの種類に関係なくコンソールを有効/無効にする方法の完全なソース コード例です。

次のクラスでは、 ...ConsoleManager.Show()を呼び出す前にどこかに書き込む必要があります。Console.Write

[SuppressUnmanagedCodeSecurity]
public static class ConsoleManager
{
    private const string Kernel32_DllName = "kernel32.dll";

    [DllImport(Kernel32_DllName)]
    private static extern bool AllocConsole();

    [DllImport(Kernel32_DllName)]
    private static extern bool FreeConsole();

    [DllImport(Kernel32_DllName)]
    private static extern IntPtr GetConsoleWindow();

    [DllImport(Kernel32_DllName)]
    private static extern int GetConsoleOutputCP();

    public static bool HasConsole
    {
        get { return GetConsoleWindow() != IntPtr.Zero; }
    }

    /// <summary>
    /// Creates a new console instance if the process is not attached to a console already.
    /// </summary>
    public static void Show()
    {
        //#if DEBUG
        if (!HasConsole)
        {
            AllocConsole();
            InvalidateOutAndError();
        }
        //#endif
    }

    /// <summary>
    /// If the process has a console attached to it, it will be detached and no longer visible. Writing to the System.Console is still possible, but no output will be shown.
    /// </summary>
    public static void Hide()
    {
        //#if DEBUG
        if (HasConsole)
        {
            SetOutAndErrorNull();
            FreeConsole();
        }
        //#endif
    }

    public static void Toggle()
    {
        if (HasConsole)
        {
            Hide();
        }
        else
        {
            Show();
        }
    }

    static void InvalidateOutAndError()
    {
        Type type = typeof(System.Console);

        System.Reflection.FieldInfo _out = type.GetField("_out",
            System.Reflection.BindingFlags.Static | System.Reflection.BindingFlags.NonPublic);

        System.Reflection.FieldInfo _error = type.GetField("_error",
            System.Reflection.BindingFlags.Static | System.Reflection.BindingFlags.NonPublic);

        System.Reflection.MethodInfo _InitializeStdOutError = type.GetMethod("InitializeStdOutError",
            System.Reflection.BindingFlags.Static | System.Reflection.BindingFlags.NonPublic);

        Debug.Assert(_out != null);
        Debug.Assert(_error != null);

        Debug.Assert(_InitializeStdOutError != null);

        _out.SetValue(null, null);
        _error.SetValue(null, null);

        _InitializeStdOutError.Invoke(null, new object[] { true });
    }

    static void SetOutAndErrorNull()
    {
        Console.SetOut(TextWriter.Null);
        Console.SetError(TextWriter.Null);
    }
} 
于 2009-04-05T07:14:31.997 に答える
15

John Leidegren はこのアイデアを否定し続けていますが、Brian は正しいです。Visual Studio で動作するようになりました。

明確にするために、WPF アプリケーションは既定ではコンソール ウィンドウを作成しません。

WPF アプリケーションを作成してから、OutputType を「コンソール アプリケーション」に変更する必要があります。プロジェクトを実行すると、WPF ウィンドウが前面にあるコンソール ウィンドウが表示されます。

見栄えはよくありませんが、アプリをコマンド ラインから実行してフィードバックを入力し、特定のコマンド オプションで WPF ウィンドウを表示したかったので、これは役に立ちました。

于 2009-04-27T11:52:01.743 に答える
4

出力ウィンドウで使用するために Console.WriteLine() を使用しています...

于 2008-10-02T05:50:56.793 に答える