Microsoft MVP성태의 닷넷 이야기
.NET Framework: 851. WinForm/WPF에서 Console 창을 띄워 출력하는 방법 [링크 복사], [링크+제목 복사],
조회: 14790
글쓴 사람
정성태 (techsharer at outlook.com)
홈페이지
첨부 파일
(연관된 글이 2개 있습니다.)

WinForm/WPF에서 Console 창을 띄워 출력하는 방법

아래의 질문이 있었는데요.

안녕하세요 디버깅시 콘솔창을 띠어서 볼수가 없나요?
; https://www.sysnet.pe.kr/3/0/5204

덧글에 쓴 대로, 다음의 글에서 아주 간단하게 설명해 주고 있습니다.

Console and WinForm together for easy debugging
; https://www.codeproject.com/Articles/9197/Console-and-WinForm-together-for-easy-debugging

일례로 WPF 응용 프로그램이라면 다음과 같이 작성해 테스트하면 됩니다.

using System;
using System.Diagnostics;
using System.Runtime.InteropServices;
using System.Windows;

namespace WpfApp1
{
    public partial class MainWindow : Window
    {
        public MainWindow()
        {
            InitializeComponent();
            NativeMethods.AllocConsole();
        }

        private void Button_Click(object sender, RoutedEventArgs e)
        {
            Console.WriteLine("test");
        }
    }


    static class NativeMethods
    {
        [DllImport("kernel32.dll", SetLastError = true)]
        [return: MarshalAs(UnmanagedType.Bool)]
        public static extern bool AllocConsole();
    }
}

여기서 한 가지 알아두어야 할 점이 있다면? Visual Studio에서 F5 디버깅으로 시작하는 경우라면 Console.WriteLine의 출력이 Visual Studio에 의해 Output 창으로 나오므로 AllocConsole로 띄운 창에는 나오지 않습니다. 따라서, Ctrl + F5 (Start Without Debugging)으로 응용 프로그램을 시작해야 정상적인 콘솔 출력을 확인할 수 있습니다.

이런 실수를 고려한다면 AllocConsole 호출 부분을 다음과 같이 수정하는 것이 좋습니다.

public MainWindow()
{
    InitializeComponent();
#if DEBUG
    if (Debugger.IsAttached == false)
    {
        NativeMethods.AllocConsole();
    }
#endif
}

이 외에 또 하나 주의할 것이 있는데요, AllocConsole을 호출하기 전 Console.Write... 관련 호출을 해서는 안 됩니다. 가령 다음의 코드는,

public partial class MainWindow : Window
{
    public MainWindow()
    {
        InitializeComponent();

        Console.WriteLine("test");
        if (Debugger.IsAttached == false)
        {
            NativeMethods.AllocConsole();
        }
    }

    private void Button_Click(object sender, RoutedEventArgs e)
    {
        Console.WriteLine("test");
    }
}

Button_Click의 Console.WriteLine 출력이 AllocConsole 창에 나오지 않게 됩니다. 마찬가지로 이런 실수를 줄이려면 AllocConsole 호출을 (WPF의 경우) App.xaml.cs에 다음과 같이 먼저 처리해 주는 것이 좋습니다.

using System.Diagnostics;
using System.Windows;

namespace WpfApp1
{
    public partial class App : Application
    {
        public App()
        {
#if DEBUG
            if (Debugger.IsAttached == false)
            {
                NativeMethods.AllocConsole();
            }
#endif
        }
    }
}

(첨부 파일은 이 글의 예제 코드를 포함합니다.)




참고로, 다음의 글도 한 번 보시고. ^^

Process.Start의 cmd.exe에서 stdin만 redirect 하는 방법
; https://www.sysnet.pe.kr/2/0/11029




[이 글에 대해서 여러분들과 의견을 공유하고 싶습니다. 틀리거나 미흡한 부분 또는 의문 사항이 있으시면 언제든 댓글 남겨주십시오.]

[연관 글]






[최초 등록일: ]
[최종 수정일: 3/31/2022]

Creative Commons License
이 저작물은 크리에이티브 커먼즈 코리아 저작자표시-비영리-변경금지 2.0 대한민국 라이센스에 따라 이용하실 수 있습니다.
by SeongTae Jeong, mailto:techsharer at outlook.com

비밀번호

댓글 작성자
 




... 31  32  33  34  35  36  37  38  39  [40]  41  42  43  44  45  ...
NoWriterDateCnt.TitleFile(s)
12643정성태5/14/20218634오류 유형: 718. 서버 유형의 COM+ 사용 시 0x80080005(Server execution failed) 오류 발생
12642정성태5/14/20219558오류 유형: 717. The 'Microsoft.ACE.OLEDB.12.0' provider is not registered on the local machine.
12641정성태5/13/20219265디버깅 기술: 179. 윈도우용 .NET Core 3 이상에서 Windbg의 sos 사용법
12640정성태5/13/202112194오류 유형: 716. RDP 연결 - Because of a protocol error (code: 0x112f), the remote session will be disconnected. [1]
12639정성태5/12/20219093오류 유형: 715. Arduino: Open Serial Monitor - The module '...\detection.node' was compiled against a different Node.js version using NODE_MODULE_VERSION
12638정성태5/12/202110018사물인터넷: 63. NodeMCU v1 ESP8266 - 펌웨어 내 파일 시스템(SPIFFS, LittleFS) 및 EEPROM 활용
12637정성태5/10/20219594사물인터넷: 62. NodeMCU v1 ESP8266 보드의 A0 핀에 다중 아날로그 센서 연결 [1]
12636정성태5/10/20219914사물인터넷: 61. NodeMCU v1 ESP8266 보드의 A0 핀 사용법 - FSR-402 아날로그 압력 센서 연동파일 다운로드1
12635정성태5/9/20219175기타: 81. OpenTabletDriver를 (관리자 권한으로 실행하지 않고도) 관리자 권한의 프로그램에서 동작하게 만드는 방법
12634정성태5/9/20218195개발 환경 구성: 572. .NET에서의 신뢰도 등급 조정 - 외부 Manifest 파일을 두는 방법파일 다운로드1
12633정성태5/7/20219731개발 환경 구성: 571. UAC - 관리자 권한 없이 UIPI 제약을 없애는 방법
12632정성태5/7/20219933기타: 80. (WACOM도 지원하는) Tablet 공통 디바이스 드라이버 - OpenTabletDriver
12631정성태5/5/20219818사물인터넷: 60. ThingSpeak 사물인터넷 플랫폼에 ESP8266 NodeMCU v1 + 조도 센서 장비 연동파일 다운로드1
12630정성태5/5/202110127사물인터넷: 59. NodeMCU v1 ESP8266 보드의 A0 핀 사용법 - CdS Cell(GL3526) 조도 센서 연동파일 다운로드1
12629정성태5/5/202111892.NET Framework: 1057. C# - CoAP 서버 및 클라이언트 제작 (UDP 소켓 통신) [1]파일 다운로드1
12628정성태5/4/20219858Linux: 39. Eclipse 원격 디버깅 - Cannot run program "gdb": Launching failed
12627정성태5/4/202110568Linux: 38. 라즈베리 파이 제로 용 프로그램 개발을 위한 Eclipse C/C++ 윈도우 환경 설정
12626정성태5/3/202110490.NET Framework: 1056. C# - Thread.Suspend 호출 시 응용 프로그램 hang 현상 (2)파일 다운로드1
12625정성태5/3/20219422오류 유형: 714. error CS5001: Program does not contain a static 'Main' method suitable for an entry point
12624정성태5/2/202113287.NET Framework: 1055. C# - struct/class가 스택/힙에 할당되는 사례 정리 [10]파일 다운로드1
12623정성태5/2/20219939.NET Framework: 1054. C# 9 최상위 문에 STAThread 사용 [1]파일 다운로드1
12622정성태5/2/20216660오류 유형: 713. XSD 파일을 포함한 프로젝트 - The type or namespace name 'TypedTableBase<>' does not exist in the namespace 'System.Data'
12621정성태5/1/202110378.NET Framework: 1053. C# - 특정 레지스트리 변경 시 알림을 받는 방법 [1]파일 다운로드1
12620정성태4/29/202112301.NET Framework: 1052. C# - 왜 구조체는 16 바이트의 크기가 적합한가? [1]파일 다운로드1
12619정성태4/28/202112824.NET Framework: 1051. C# - 구조체의 크기가 16바이트가 넘어가면 힙에 할당된다? [2]파일 다운로드1
12618정성태4/27/202111297사물인터넷: 58. NodeMCU v1 ESP8266 CP2102 Module을 이용한 WiFi UDP 통신 [1]파일 다운로드1
... 31  32  33  34  35  36  37  38  39  [40]  41  42  43  44  45  ...