Rob*_*Rob 101 .net c# wpf console
我从一个非常简单的WPF测试应用程序使用Console.WriteLine(),但是当我从命令行执行应用程序时,我看不到任何内容被写入控制台.有谁知道这里会发生什么?
我可以通过在VS 2008中创建WPF应用程序来重现它,并简单地在执行任何地方添加Console.WriteLine("text").有任何想法吗?
我现在需要的只是Console.WriteLine()这么简单.我意识到我可以使用log4net或其他日志记录解决方案,但我真的不需要这个应用程序的那么多功能.
编辑:我应该记得Console.WriteLine()是用于控制台应用程序.哦,好吧,没有愚蠢的问题,对吗?:-)我现在只使用System.Diagnostics.Trace.WriteLine()和DebugView.
Bri*_*ian 119
右键单击项目,"属性","应用程序"选项卡,将"输出类型"更改为"控制台应用程序",然后它还将具有控制台.
Pho*_*bis 110
您可以使用
Trace.WriteLine("text");
Run Code Online (Sandbox Code Playgroud)
这将输出到Visual Studio中的"输出"窗口(调试时).
确保包含诊断程序集:
using System.Diagnostics;
Run Code Online (Sandbox Code Playgroud)
Joh*_*ren 90
在实际调用任何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);
}
}
Run Code Online (Sandbox Code Playgroud)
小智 11
虽然John Leidegren一直在抨击这个想法,但Brian是正确的.我刚刚在Visual Studio中使用它.
要清楚,WPF应用程序默认情况下不会创建控制台窗口.
您必须创建WPF应用程序,然后将OutputType更改为"控制台应用程序".运行项目时,您将看到一个控制台窗口,其前面有WPF窗口.
它看起来不太漂亮,但我发现它很有用,因为我希望我的应用程序从命令行运行,并在那里有反馈,然后对于某些命令选项,我将显示WPF窗口.
通过使用命令行重定向可以查看用于控制台的输出.
例如:
C:\src\bin\Debug\Example.exe > output.txt
Run Code Online (Sandbox Code Playgroud)
将所有内容写入output.txt
文件.
旧帖子,但我碰到了这个,所以如果你想在Visual Studio中的WPF项目中输出一些东西,那么现代的方法是:
包括这个:
using System.Diagnostics;
Run Code Online (Sandbox Code Playgroud)
然后:
Debug.WriteLine("something");
Run Code Online (Sandbox Code Playgroud)
归档时间: |
|
查看次数: |
101293 次 |
最近记录: |