前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
工具
TVP
发布
社区首页 >专栏 >WinForm程序启动控制台窗口Console

WinForm程序启动控制台窗口Console

作者头像
跟着阿笨一起玩NET
发布2018-09-19 15:49:50
2.2K0
发布2018-09-19 15:49:50
举报

本文转载:http://blog.csdn.net/oyi319/article/details/5753311

2.WinForm程序和控制台窗口Console

如果你调试过SharpDevelop的源程序,会发现它在DEBUG模式时会出现一个控制台窗口,以显示日志信息。或许我使用的方法与其不同,不过你可以试一试,写出我们自己的调试日志代码。

首先要解决的问题是如何在Debug模式时显示Console窗口。我确定,这是一个WinForm项目,也没有改过它的输出类型。我们需要在项目的入口点使用一些API函数将控制台显示出来:

它们是 AllocConsole 和 FreeConsole。

[c-sharp] view plaincopy

代码语言:javascript
复制
[DllImport("kernel32.dll")]  
public static extern Boolean AllocConsole();  
[DllImport("kernel32.dll")]  
public static extern Boolean FreeConsole();  

然后我们使它在Main()开始处判断DEBUG编译标记,调用AllocConsole方法显示控制台,然后在Main()的结束处判断DEBUG编译标记,调用FreeConsole方法关闭控制台。这样,我们就可以使用Console.Write等方法将调试信息显示在这个控制台窗口里。

为了达到更好的效果,我们写一个Shell类,用它来封装Console.WriteLine方法,输出个性化信息。我是这样做的,根据输出到控制台的文本的前几个字判断为“警告”、“错误”、“注意”时,输出带有黄色、红色、绿色的文字,其他输出信息输出控制台缺省的灰色文字,以起到区分效果,还要在每条信息前加上输出信息的当时时间。

这个Shell类是这样的:

[c-sharp] view plaincopy

代码语言:javascript
复制
/// <summary>  
/// 与控制台交互  
/// </summary>  
static class Shell  
{  
 /// <summary>  
 /// 输出信息  
 /// </summary>  
 /// <param name="format"></param>  
 /// <param name="args"></param>  
 public static void WriteLine(string format, params object[] args)  
    {  
        WriteLine(string.Format(format, args));  
    }  
 
 /// <summary>  
 /// 输出信息  
 /// </summary>  
 /// <param name="output"></param>  
 public static void WriteLine(string output)  
    {  
        Console.ForegroundColor = GetConsoleColor(output);  
        Console.WriteLine(@"[{0}]{1}", DateTimeOffset.Now, output);  
    }  
 
 /// <summary>  
 /// 根据输出文本选择控制台文字颜色  
 /// </summary>  
 /// <param name="output"></param>  
 /// <returns></returns>  
 private static ConsoleColor GetConsoleColor(string output)  
    {  
 if (output.StartsWith("警告")) return ConsoleColor.Yellow;  
 if (output.StartsWith("错误")) return ConsoleColor.Red;  
 if (output.StartsWith("注意")) return ConsoleColor.Green;  
 return ConsoleColor.Gray;  
    }  
}  

那么程序入口函数Main代码如下:

[c-sharp] view plaincopy

代码语言:javascript
复制
/// <summary>  
/// 应用程序的主入口点。  
/// </summary>  
[STAThread]  
static void Main()  
{  
#if DEBUG  
    AllocConsole();  
    Shell.WriteLine("注意:启动程序...");  
 
    Shell.WriteLine("/tWritten by Oyi319");  
    Shell.WriteLine("/tBlog: http://blog.csdn.com/oyi319");  
    Shell.WriteLine("{0}:{1}", "警告", "这是一条警告信息。");  
    Shell.WriteLine("{0}:{1}", "错误", "这是一条错误信息!");  
    Shell.WriteLine("{0}:{1}", "注意", "这是一条需要的注意信息。");  
    Shell.WriteLine("");  
#endif  
    Application.EnableVisualStyles();  
    Application.SetCompatibleTextRenderingDefault(false);  
    Application.Run(new Form1());  
#if DEBUG  
    Shell.WriteLine("注意:2秒后关闭...");  
    Thread.Sleep(2000);  
    FreeConsole();  
#endif  
}  

现在这个控制台窗口,只会在DEBUG模式时显示,而在Release编译时不会出现。 这是不是你想要的调试方法呢?

本文参与 腾讯云自媒体分享计划,分享自作者个人站点/博客。
原始发表:2014-09-26 ,如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 作者个人站点/博客 前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体分享计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
目录
  • 2.WinForm程序和控制台窗口Console
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档