天天看點

WinForm程式啟動控制台視窗Console

如果你調試過SharpDevelop的源程式,會發現它在DEBUG模式時會出現一個控制台視窗,以顯示日志資訊。或許我使用的方法與其不同,不過你可以試一試,寫出我們自己的調試日志代碼。

首先要解決的問題是如何在Debug模式時顯示Console視窗。我确定,這是一個WinForm項目,也沒有改過它的輸出類型。我們需要在項目的入口點使用一些API函數将控制台顯示出來:

它們是 AllocConsole 和 FreeConsole。

[DllImport("kernel32.dll")]  

public static extern Boolean AllocConsole();  

public static extern Boolean FreeConsole();  

然後我們使它在Main()開始處判斷DEBUG編譯标記,調用AllocConsole方法顯示控制台,然後在Main()的結束處判斷DEBUG編譯标記,調用FreeConsole方法關閉控制台。這樣,我們就可以使用Console.Write等方法将調試資訊顯示在這個控制台視窗裡。

為了達到更好的效果,我們寫一個Shell類,用它來封裝Console.WriteLine方法,輸出個性化資訊。我是這樣做的,根據輸出到控制台的文本的前幾個字判斷為“警告”、“錯誤”、“注意”時,輸出帶有黃色、紅色、綠色的文字,其他輸出資訊輸出控制台預設的灰色文字,以起到區分效果,還要在每條資訊前加上輸出資訊的當時時間。

這個Shell類是這樣的:

/// <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));  

    }  

    /// <param name="output"></param>  

    public static void WriteLine(string output)  

        Console.ForegroundColor = GetConsoleColor(output);  

        Console.WriteLine(@"[{0}]{1}", DateTimeOffset.Now, output);  

    /// 根據輸出文本選擇控制台文字顔色  

    /// <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代碼如下:

/// 應用程式的主入口點。  

[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());  

    Shell.WriteLine("注意:2秒後關閉...");  

    Thread.Sleep(2000);  

    FreeConsole();  

現在這個控制台視窗,隻會在DEBUG模式時顯示,而在Release編譯時不會出現。 這是不是你想要的調試方法呢?

WinForm程式啟動控制台視窗Console