WinForm程序启动控制台窗口Console

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

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

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

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

它们是 AllocConsole 和 FreeConsole。

[c-sharp] view plaincopy

  1. [DllImport("kernel32.dll")]
  2. public static extern Boolean AllocConsole();
  3. [DllImport("kernel32.dll")]
  4. public static extern Boolean FreeConsole();

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

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

这个Shell类是这样的:

[c-sharp] view plaincopy

  1. /// <summary>
  2. /// 与控制台交互
  3. /// </summary>
  4. static class Shell
  5. {
  6. /// <summary>
  7. /// 输出信息
  8. /// </summary>
  9. /// <param name="format"></param>
  10. /// <param name="args"></param>
  11. public static void WriteLine(string format, params object[] args)
  12. {
  13. WriteLine(string.Format(format, args));
  14. }
  15. /// <summary>
  16. /// 输出信息
  17. /// </summary>
  18. /// <param name="output"></param>
  19. public static void WriteLine(string output)
  20. {
  21. Console.ForegroundColor = GetConsoleColor(output);
  22. Console.WriteLine(@"[{0}]{1}", DateTimeOffset.Now, output);
  23. }
  24. /// <summary>
  25. /// 根据输出文本选择控制台文字颜色
  26. /// </summary>
  27. /// <param name="output"></param>
  28. /// <returns></returns>
  29. private static ConsoleColor GetConsoleColor(string output)
  30. {
  31. if (output.StartsWith("警告")) return ConsoleColor.Yellow;
  32. if (output.StartsWith("错误")) return ConsoleColor.Red;
  33. if (output.StartsWith("注意")) return ConsoleColor.Green;
  34. return ConsoleColor.Gray;
  35. }
  36. }

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

[c-sharp] view plaincopy

  1. /// <summary>
  2. /// 应用程序的主入口点。
  3. /// </summary>
  4. [STAThread]
  5. static void Main()
  6. {
  7. #if DEBUG
  8. AllocConsole();
  9. Shell.WriteLine("注意:启动程序...");
  10. Shell.WriteLine("/tWritten by Oyi319");
  11. Shell.WriteLine("/tBlog: http://blog.csdn.com/oyi319");
  12. Shell.WriteLine("{0}:{1}", "警告", "这是一条警告信息。");
  13. Shell.WriteLine("{0}:{1}", "错误", "这是一条错误信息!");
  14. Shell.WriteLine("{0}:{1}", "注意", "这是一条需要的注意信息。");
  15. Shell.WriteLine("");
  16. #endif
  17. Application.EnableVisualStyles();
  18. Application.SetCompatibleTextRenderingDefault(false);
  19. Application.Run(new Form1());
  20. #if DEBUG
  21. Shell.WriteLine("注意:2秒后关闭...");
  22. Thread.Sleep(2000);
  23. FreeConsole();
  24. #endif
  25. }

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

时间: 2024-10-25 14:14:20

WinForm程序启动控制台窗口Console的相关文章

C# WinForm程序中强制退出程序以及启动程序

C# WinForm程序 退出方法: Application.Exit();//强制所有消息终止,退出所有窗体,但是若有托管线程(非主线程),也无法干净地退出this.Close();//只是关闭当前窗口,若不是主窗体的话,是无法退出程序的,但是若有托管线程(非主线程),也无法干净地退出Application.ExitThread();//强制终止调用线程上的所有消息,同样面临其他线程无法正确退出的问题System.Environment.Exit(0);//这是最彻底的退出,不管什么线程都被强

WinForm 之 程序启动不显示主窗体

在 WinForm 程序启动时,不显示主窗体的实现方法主要有以下5种,第五种最简单,而且效果也不错,第四种方法也值得推荐. 实例代码如下: //隐藏窗体的方法1/5:不指定任何窗体为主窗体 //注意:通常,在一个程序中,关闭主窗体,就可以关闭应用程序. //但是在没有主窗体中,不行. //只能使用Application.Exit()才能关闭应用程序. //using可以保证Application结束前,关闭MyMainForm using (new Form1()) { Application.

微软 WCF的几种寄宿方式,寄宿IIS、寄宿winform、寄宿控制台、寄宿Windows服务

WCF寄宿方式是一种非常灵活的操作,可以在IIS服务.Windows服务.Winform程序.控制台程序中进行寄宿,从而实现WCF服务的运行,为调用者方便.高效提供服务调用.本文分别对这几种方式进行详细介绍并开发例子进行说明,以求大家对WCF寄宿的方式进行全面的认识和了解. 1. WCF服务的IIS服务寄宿 我在我前面几篇WCF开发框架的介绍文章中,介绍过了WCF常用的一种寄宿方式,IIS服务寄宿.这种寄宿方式是最为方便的方式,而且由于服务只需要IIS运行就能自动运行起来,因此广为使用. 创建这

C#控制台窗口的几个常用方法

Console.Read()方法:          从控制台窗口读取一个字符,返回int值 Console.ReadLine()方法:    从控制台窗口读取一行文本,返回string值 Console.ReadKey()方法:    监听键盘事件,可以理解为按任意键执行 Console.Write()方法:         将制定的值写入控制台窗口 Console.WriteLine()方法:   将制定的值写入控制台窗口,但在输出结果的最后添加一个换行符 using System;usin

在控制台程序中隐藏控制台窗口

大家都知道,当编写一个win32 console application时,当运行此类程序的时候默认情况下会有一个类似DOS窗口的console窗口,但是有的时候我们只想在程序中运行一段功能代码,不希望显示这个console窗口,让代码执行完毕之后程序自动退出. 下面就介绍一下,如何隐藏win32 console application的console窗口 因为此种方法是通过设置编译器的链接开关来实现,所以让我们来看一下编译器的链接开关选项(也就是linker选项). 首先我们来看一下linke

C# windows服务启动winform程序不显示UI问题解决

由于工作需要写一个解决winform程序自动更新下载重启的自动更新程序,之前用控制台全部实现,然而换成windows  service出现了两个问题,一个是路径问题(http://baidu.com),一个是服务启动其他winform程序不显示UI问题. 本篇解决UI显示问题. 以下为引用尤尼博文(原文地址:http://www.cnblogs.com/luxilin/p/3347212.html): 我开发的系统中有一接口程序(这里就称Task,是一个C#的Console Applicatio

如何:在 Winform 动态启动、控制台命令行?

需求   winForm 程序输出类型为 windows 程序(不是命令行程序)   在运行时想输入一些信息编译开发调试,如何实现这一功能 解答:  AllocConsole.FreeConsole 这两个 API 可以在任何时候调用和关闭 命令行. 代码演示:API 部分 using System;using System.Collections.Generic;using System.Linq;using System.Text;using System.Runtime.InteropSe

吉特仓库管理系统(开源)-如何在网页端启动WinForm 程序

原文:吉特仓库管理系统(开源)-如何在网页端启动WinForm 程序 在逛淘宝或者使用QQ相关的产品的时候,比如淘宝我要联系店家点击旺旺图标的时候能够自动启动阿里旺旺进行聊天.之前很奇怪为什么网页端能够自动启动客户端程序,最近在开发吉特仓储管理系统的时候也遇到一个类似的问题,因为使用网页端的打印效果并不是太好,之前也写过关于打印相关的文章可以查阅,我需要使用WinForm客户端来驱动打印,但是我又不想重新开发Winform客户端的所有功能,只要能够使用winform驱动打印即可.我就需要一个类似

C# winForm程序开机启动和托盘显示 (转http://blog.csdn.net/xinyue3054/article/details/6599508)

这段时间一直进行cs项目,故整理下开机自动运行.托盘.显示.隐藏. (1).在窗口上点击关闭按钮或者最小化时将托盘显示: (2).双击托盘图标显示窗口: (3).右键点击托盘图标提供三个菜单选项,“退出”.“隐藏”.“显示”: (4).程序可以设置开机启动,隐藏任务栏显示.就这四个小功能. 1.建一个WinForm程序—FormAuto,将其属性ShowInTaskbar改为false,这样程序将不会在任务栏中显示:将MaximizeBox属性设置为false,屏蔽掉最大化按钮:把StartPo