'HOWTO'에 해당되는 글 11건

  1. 2008.01.16 팝업 메뉴..
  2. 2008.01.16 시리얼 통신 자료 받기 메세지 Serial Port DataReceived Event
  3. 2008.01.16 크로스 스레드, 방법: 스레드로부터 안전한 방식으로 Windows Forms 컨트롤 호출
  4. 2008.01.16 WaitForSingleObject 관련 스레드 다루기 1
  5. 2008.01.16 VS2005 Remote Dubug
  6. 2008.01.16 C++ 라이브러리를 CLI로 싸서 C# 에서 사용하기 2
  7. 2008.01.16 How do i use DOM xml 다루기
  8. 2008.01.16 BSTR 형변환
  9. 2008.01.16 응용프로그램 경로 알기
  10. 2008.01.16 CWaitCursor, GetTempFileName, LoadLibary, GetProcAdress

팝업 메뉴..

Program/C | C++ 2008. 1. 16. 22:57

# 메세지 등록
ON_WM_CONTEXTMENU()

# OnContextMenu 핸들러 구현
CMenu  main_menu;
CMenu *menu;
main_menu.LoadMenu(IDR_MENU);
menu = main_menu.GetSubMenu(3);
// IDR_MENU의 3번재 탭에 팝업 메뉴를 구성하였기 때문에 3번재 서브 메뉴를 가져옴

# 선택된 메뉴에 대한 핸들러 등록, 핸들러 구현
ON_COMMAND(IDC_DELETE_FILE,     OnMenu_Delete)

'Program > C | C++' 카테고리의 다른 글

파일 관련 함수들..  (0) 2008.01.16
OLE Drag And Drop  (0) 2008.01.16
마우스 포인터를 이용한 윈도우 핸들  (0) 2008.01.16
:

시리얼 통신 자료 받기 메세지 Serial Port DataReceived Event

Program/C# 2008. 1. 16. 09:47
http://forums.microsoft.com/MSDN/ShowPost.aspx?PostID=22421&SiteID=1

using System;
using System.Collections.Generic;
using System.ComponentModel;
using System.Data;
using System.Drawing;
using System.Text;
using System.Windows.Forms;
using System.IO.Ports;


namespace SerialTest
{


    public partial class Form1 : Form
    {
       // Setup the port
        private SerialPort port = new SerialPort("COM8", 38400, Parity.None, 8, StopBits.One);
          
        public Form1()
        {
            InitializeComponent();
             // Enable Event handler
            port.DataReceived += new SerialDataReceivedEventHandler(port_DataReceived);
        }
       
        private void port_DataReceived(object sender, SerialDataReceivedEventArgs e)
        {// Event for receiving data
            // Read the buffer to text box.
            statusBar1.Text = "Getting Data";
            statusBar1.Refresh();
            txtData.Text = txtData.Text + port.ReadExisting();
        }
       
        private void btn_Send_Click(object sender, EventArgs e)
        {// Button to send test data
            try
            {
                port.WriteLine("This is a test Line");

            }
            catch (Exception wex)
            {
                MessageBox.Show(wex.ToString());
            }
        }
       
        private void btn_OpenPort_Click(object sender, EventArgs e)
        {// Button to open the port
            // Begin communications
            if (port.IsOpen == false)
                try
                {
                    port.Open();
                }

                catch (Exception oex)
                {
                    MessageBox.Show(oex.ToString());
                }
        }
      
        private void btn_ClosePort_Click(object sender, EventArgs e)
        { // Button to close the port
            port.Close();
        }

        private void  btn_Close_Click(object sender, EventArgs e)
        {// Button to exit the app.
            this.Close();
        }
:

크로스 스레드, 방법: 스레드로부터 안전한 방식으로 Windows Forms 컨트롤 호출

Program/C# 2008. 1. 16. 09:46

스레드로부터 안전한 방식으로 Windows Forms 컨트롤을 호출하려면

  1. 컨트롤의 InvokeRequired 속성을 쿼리합니다.

  2. InvokeRequiredtrue를 반환하는 경우에는 컨트롤을 실제로 호출하는 대리자를 사용하여 Invoke를 호출합니다.

  3. InvokeRequiredfalse를 반환하는 경우에는 컨트롤을 직접 호출합니다.

다음 코드 예제에서는 SetText라는 유틸리티 메서드에서 이 논리를 구현합니다. SetTextDelegate 대리자 형식은 SetText 메서드를 캡슐화합니다. TextBox 컨트롤의 InvokeRequiredtrue를 반환하면 SetText 메서드는 SetTextDelegate 인스턴스를 만들고 폼의 Invoke 메서드를 호출합니다. 그러면 TextBox 컨트롤을 만든 스레드에서 SetText 메서드가 호출되고 이 스레드 컨텍스트에서 Text 속성이 직접 설정됩니다.


## 그렇다면 모든 컨트롤들에 대해서 이와 같은 작업을 각각 해줘야 하는 것인가???


http://msdn2.microsoft.com/ko-kr/library/ms171728(VS.80).aspx

'Program > C#' 카테고리의 다른 글

C# Dll Load  (1) 2008.01.17
C# 데이터 베이스 개념  (0) 2008.01.16
시리얼 통신 자료 받기 메세지 Serial Port DataReceived Event  (0) 2008.01.16
:

WaitForSingleObject 관련 스레드 다루기

Program/C | C++ 2008. 1. 16. 09:44

WaitForSingleObject() - 보통 FindFirstChangeNotification, FindNext..., FindClose... 등과 쓰임
1. 용도

    Thread가 특정 signal이 발생할 때까지 정지해 있다가,
    signal을 받으면, 작업을 수행하고 다시 정지 상태로 돌아가게할 필요를
    자주 느끼게 된다.
    WaitForSingleObject()와 WaitForMultipleObjects()를 사용하여
    이런 need를 해결할 수 있다.
    이 함수들은 CreateEvent(), SetEvent(), ResetEvent()와 함께 사용한다.
   
2. WaitForSingleObject()

    이 함수는 하나의 Event object를 만들어 놓고,
    이 Event가 signal(SetEvent())될 때까지 기다린다.
   
    DWORD WaitForSingleObject(
      HANDLE hHandle,          // Event object handle
      DWORD dwMilliseconds // time-out interval. 단위는 millisecond
                                         // INFINITE 으로 설정할 경우, 무한정 기다린다.
    );
   
    return value:
        1) WAIT_FAILED: fail. GetLastError()로 원인을 알 수 있다. 이 경우는 logic을 빠져나간다.
        2) WAIT_ABANDONED: 이 경우는 Event object를 reset하고, 다시 WaitForSingleObject()를 호출한다.
        3) WAIT_OBJECT_0: 기다리던 Event가 signal된 경우.
        4) WAIT_TIMEOUT: time-out이 된 경우.
       
3. Sample code

    DWORD  ret;
   
    while( TRUE )  {
        ret = WaitForSingleObject( hHandle, INFINITE );
   
        if( ret == WAIT_FAILED )
            return 0;
        else if( ret == WAIT_ABANDONED ) {
            ResetEvent( hHandle );
            continue;
        }
        else if( WAIT_TIMEOUT )
            continue;
        else {
            ResetEvent( hHandle );
            // 원하는 작업을 처리한다.
        }
    }

'Program > C | C++' 카테고리의 다른 글

마우스 포인터를 이용한 윈도우 핸들  (0) 2008.01.16
CLR 정의  (0) 2008.01.16
VS2005 Remote Dubug  (0) 2008.01.16
:

VS2005 Remote Dubug

Program/C | C++ 2008. 1. 16. 09:43
VS2005에서 원격 디버깅 VS2005, .NET 2.0

2006/01/24 16:29

http://blog.naver.com/saltynut/120021507832

Written by 안재우(Jaewoo Ahn), 닷넷엑스퍼트(.netXpert)

 

고객사에서 Visual Studio 2005에서의 원격 디버깅 사용법에 대한 문의가 온 김에, 내용을 좀 정리해볼까 합니다. 원격 디버깅은 상당히 유용한 기능 임에도 불구하고, 대부분의 개발자들이 좀처럼 사용하지 않는 기능입니다. 간혹 여러가지 여건 때문에 쓸 수 없는 상황에 처해 있는 경우도 있겠지만, 대다수는 사실 '몰라서' 사용하지 못하고 있는 형편입니다.

 

이번 글에서는 원격 디버깅의 개념, Visual Studio 2005에서의 원격 디버깅에 대해 알아보고, 몇가지 주의할 사항도 함께 살펴보도록 하겠습니다.

 

원격 디버깅이란?

네이버 용어 사전 설명으로는 '원격 시스템에서 사용되는 원격 제어 콘솔에서 프로그램을 수정하고 시험하는 것'이라고 합니다. 사실 이걸로는 정확하게 무슨 말이 잘 와 닿지 않을 수 있으므로, 좀 풀어서 설명해보도록 하죠.

 

일반적으로 우리가 디버깅을 시작하려면 개발툴(Visual Studio)에서 디버그 모드(F5 키)로 애플리케이션을 시작하게 됩니다. 디버그 모드로 애플리케이션을 구동하면, 당연히 애플리케이션을 호스트하는 프로세스가 만들어질테고, 프로세스는 자신이 필요한 모듈(.exe, .dll)을 로드하게 됩니다. 이 때, 디버그 모드에서는 모듈에 해당하는 디버그 심볼 파일(.pdb)을 같이 로드하게 됩니다.

 

그런데, 디버그 모드로 '시작'한다는 의미는 애플리케이션을 처음부터 새로 시작한다는 의미입니다. 그리고 디버그 모드를 '종료'하면 애플리케이션도 같이 종료되어 버립니다. 당장 코드를 개발 중일 때는 이러한 방법으로 디버깅을 할 수 있겠지만, 항상 개발을 하다보면 멀쩡하게 잘 돌아가던 애플리케이션에서 말썽이 생기는 경우가 많습니다. 즉, 이미 돌아가고 있는 애플리케이션에 대해 디버깅을 할 수 있는 방법은 없느냐는 것이죠. 이 형태의 디버깅은 In-Process 모드와 유사하다고 볼 수 있습니다.

 

여기에서 먼저 도입된 개념이 '프로세스 디버깅'입니다. Visual Studio에서는 이미 실행 중인 프로세스에 연결(Attach)시켜서 디버깅을 수행할 수 있습니다. 디버깅을 종료하면 프로세스에서 분리(Detach)시키고, 애플리케이션 프로세스 자체는 여전히 구동되게 됩니다. 이 형태의 디버깅은 Out-Of-Process 모드와 유사하다고 볼 수 있습니다.

 

원격 디버깅은 프로세스 디버깅을 로컬 컴퓨터의 바운더리를 벗어나도록 확장한 개념입니다. 즉 원격 컴퓨터에서 실행되고 있는 프로세스를 내 로컬 컴퓨터의 디버거를 사용하여 디버깅할 수 있게 해줍니다.

 

참고로 약간 변칙적인 녀석 중 하나로 실행 중인 프로그램에 심각한 오류가 발생하면 Visual Studio 디버거를 자동으로 실행할 수 있게 해주는 Just-In-Time 디버깅도 있습니다.

 

원격 디버깅이 왜 필요한가?

로컬 디버깅의 경우, 로컬에 디버거(개발툴)가 설치되어 있다는 것을 전제로 합니다. 그러나 항상 모든 컴퓨터에 디버거(개발툴)이 설치되어 있지는 않겠죠?

예를 들어, 개발자 컴퓨터에서는 이상없이 잘 돌던 프로그램이 서버나 다른 PC에서 실행하면 문제가 발생하는 경우가 있습니다. 이런 경우, 디버깅을 해보기 위해 서버나 그 PC에 디버거(개발툴)를 설치해야 할까요?

실제로 제가 경험한 몇몇 회사에서는 서버에 Visual Studio를 설치해서 디버깅을 하는 웃지 못할 형태로 작업을 하기도 했습니다. 그런데 간혹 가다보면 Visual Studio를 설치하고 나면 제대로 동작해버리는 상황도 발생하더군요. :-)

 

전통적으로 애플리케이션을 배포하고 난 후에는 디버깅이 아닌 다른 방법을 사용해서 문제점을 추적해야 합니다. 문제점 추적 방법에 대한 다양한 개발자들의 행태(?)를 살펴보면...

 

1. 초급 : Hello World를 사랑하는 사람들(Windows 애플리케이션에서는 메시지 박스를, Java 스크립트에서는 alert를, ASP나 ASP.NET에서는 Response.Write를 찍어대는 사람들을 의미합니다)

2. 중급 : 로그 찍기. 파일, 이벤트 로그 등에 로그를 기록합니다.

3. 고급 : 기본적으로는 2번과 동일하지만, 해당 PC에 로그를 기록하는 것이 아니라 원격 로그 수집기에 로그를 기록하게 합니다. DB에 기록하거나 에러 발생 시 원격 통신으로 전송한다든지.. 성능 카운터를 활용하거나 WMI를 이용하기도 합니다.

 

로그 기록 형태가 가장 일반적이지만, 이를 통해 문제를 정확하게 파악하는 것은 디버깅에 비해 상대적으로 쉽지 않습니다. 과거에 일어난 일을 '단서'를 가지고 추정해 나가야 하기 때문입니다.

 

원격 디버깅은 이러한 상황, 즉 로그 기록만으로는 정확한 내용을 알 수 없는 경우에 사용할 수 있는 해결책 중 하나입니다. 원격 컴퓨터에 개발툴을 설치하지 않고도 원격에서 디버깅을 수행할 수 있게 해줍니다.

 

Visual Studio에서 원격 디버깅의 구동 원리

Visual Studio 2005에서 원격 디버깅이 구동되는 형태를 도식화하면 대략 다음 그림과 같습니다. 그림을 보면 이해가 갈 것이라고 판단되므로 별다른 설명은 하지 않겠습니다.

 


 

위 그림처럼 디버거 역할을 하는 로컬 컴퓨터의 VS2005와 실행 중인 프로세스(App1.exe)를 중개하는 역할은 원격 디버깅 모니터(Remote Debugging Monitor)인 msvsmon.exe가 수행합니다. 과거에 일부 원격 디버깅 시나리오에서만 유사한 역할을 수행한 Machine Debug Manager(mdm.exe)가 있었지만, 이는 더이상 사용되지 않습니다. VS2005에서는 T-SQL 디버깅을 제외한 모든 원격 디버깅 시나리오에서 msvsmon.exe가 사용됩니다. 커맨드라인의 MDM에 비해 msvsmon.exe는 GUI를 제공합니다.

 

Visual Studio에서 원격 디버깅 구성

 

위 그림을 살펴보다 보면 원격 디버깅을 하기 전에 몇가지 설정이 필요할 것이라는 점을 추측할 수 있습니다.

1. 원격 디버깅 모니터(msvsmon.exe)를 원격 컴퓨터에 설치

2. 원격 디버깅을 위한 보안 권한 설정

3. 네트워크 방화벽 설정(개인 방화벽 포함, 로컬/원격 모두)

 

1, 3번에 대한 것은 다음 MSDN 문서를 참조하기 바랍니다. 아직 한글판이 나오지 않아서 임시 URL인 것 같습니다.

http://msdn2.microsoft.com/ko-kr/library/y7f5zaaa.aspx

 

2번은 상대적으로 간단해졌는데, 과거에 권한 설정 문제가 비교적 복잡했던 것에 비해서 이제는 원격 디버깅 모니터의 Tools/Permission 메뉴에서 설정할 수 있습니다.

 

원격 디버깅 사용법

구성이 끝났으면, 이제 사용법은 간단합니다.

 

1. 원격 컴퓨터에서 원격 디버깅 모니터를 실행합니다. 다음은 실행된 모습입니다.


2. 디버깅할 대상이 되는 프로세스가 아직 실행되어 있지 않다면, 실행합니다. 이 프로세스와 관련 DLL들은 당연히 디버그 모드로 빌드되어 있어야 하며, 디버깅이 사용가능한 상황이어야 합니다.

 

3. 로컬 컴퓨터에서 VS 2005를 실행하고, 디버깅할 프로세스 및 DLL이 포함된 솔루션 또는 프로젝트 파일을 엽니다.

 

4. Debug 메뉴에서 Attach to Process를 선택합니다. Qualifier에 msvsmon.exe를 실행하고 있는 원격 컴퓨터의 이름(또는 IP)을 입력 후, 엔터 키 또는 Refresh 버튼을 누릅니다.


5. Available Processes에서 디버깅할 프로세스를 선택한 후 Attach 버튼을 누르면...

이제 디버깅 시작입니다!


원격 디버깅 시 주의할 사항

이제 사용법은 알았고, 원격 디버깅에는 몇가지 주의할 사항이 있습니다.

 

첫째, 기본적으로 원격 디버깅은 로그 추적/ 트레이스 등으로 해결할 수 없을 때 사용되는 보조적인 방법이라는 것입니다. 무조건 모든 문제를 원격 디버깅으로 해결하려고 드는 것은 바람직한 것이 아니라는 점입니다.

 

두번째, 디버깅을 하면서 브레이크를 걸었을 때, 실행 중인 프로세스 자체도 정지되어 있는 상태가 된다는 것입니다. 일반적인 애플리케이션이라면 별 상관없지만, 웹 애플리케이션처럼 서버 애플리케이션인 경우에는 문제가 심각해질 수 있습니다.

예를 들어 ASP.NET 애플리케이션을 원격 디버깅하고 있다고 가정해 봅시다. 내가 브레이크 포인트를 걸고 디버깅을 하고 있는 도중에는 ASP.NET 웹 애플리케이션이 다른 사용자의 요청에 응답할 수 없게 됩니다.

실제로 있었던 웃지못할 사건 중 하나는.. 모 고객사에서 실행 중인 서버에서 이상한 문제점이 발견되었는데, 로그나 트레이스를 하는 것이 아무것도 없어서 결국 원격 디버깅을 걸어서 문제점을 찾아 해결했습니다. 그러면서 원격 디버깅 사용법을 가르쳐 주고 나왔는데.. 그 담부터 그 개발자가 원격 디버깅을 지나치게 남발하면서 문제가 생겼습니다. 툭하면 서버가 먹통이 되어 버린다고 사용자들이 난리가 난거죠. 알고보니 개발자가 원격 디버깅을 걸어 둔 채 점심식사를 하러 갔다고 합니다. -_-;;

 

결론적으로 Visual Studio 2005에서 원격 디버깅은 보다 설정 및 사용법이 간편해지긴 했지만, 원격 디버깅은 어쩔 수 없는 경우에 사용하는 히든 카드(?)라는 점이며, 사용 시에는 가급적 빠른 시간 내에 작업을 마치는 것이 바람직하다는 것입니다.

마지막으로 원격 디버깅은 .NET으로 작성된 프로그램뿐만 아니라 Native, Script, T-SQL 등에 모두 사용이 가능하다는 점을 유념하시기 바랍니다.

'Program > C | C++' 카테고리의 다른 글

CLR 정의  (0) 2008.01.16
C++ 라이브러리를 CLI로 싸서 C# 에서 사용하기  (2) 2008.01.16
How do i use DOM xml 다루기  (0) 2008.01.16
:

C++ 라이브러리를 CLI로 싸서 C# 에서 사용하기

Program/C | C++ 2008. 1. 16. 09:43
http://blog.naver.com/limdp99?Redirect=Log&logNo=60034273093

'Program > C | C++' 카테고리의 다른 글

VS2005 Remote Dubug  (0) 2008.01.16
How do i use DOM xml 다루기  (0) 2008.01.16
BSTR 형변환  (0) 2008.01.16
:

How do i use DOM xml 다루기

Program/C | C++ 2008. 1. 16. 09:42
C++에서 DOM 개체 사용법, XML 데이터를 조작하는 기본 적인 방법
C++ 뿐만 아니라 기타 다른 언어에 대한 설명도 나와있습니다.
http://msdn2.microsoft.com/en-us/library/ms756005.aspx

첨부 파일은 : XML을 DOM으로 다루기 위한 헬퍼를 만들어 본XmlHelper.hXmlHelper.cpp 것..

'Program > C | C++' 카테고리의 다른 글

C++ 라이브러리를 CLI로 싸서 C# 에서 사용하기  (2) 2008.01.16
BSTR 형변환  (0) 2008.01.16
응용프로그램 경로 알기  (0) 2008.01.16
:

BSTR 형변환

Program/C | C++ 2008. 1. 16. 09:40
# BSTR >> char *

Char tmp[32];
BSTR tmpValue = NULL;
tmpValue = (_bstr_t)tmp;

# char* >> BSTR
(char*)(_bstr_t(tmpValue));

'Program > C | C++' 카테고리의 다른 글

How do i use DOM xml 다루기  (0) 2008.01.16
응용프로그램 경로 알기  (0) 2008.01.16
문자열에 대한 정리  (0) 2008.01.16
:

응용프로그램 경로 알기

Program/C | C++ 2008. 1. 16. 09:40
 응용프로그램 포인터
    AfxGetApp();

# 방법 1
theApp->GetConfig()->m_pPath;

# 방법 2
    //실행파일까지 포함한 경로
    CString string;
    char filename[1024];
    GetModuleFileName(NULL, filename, 1024);
    string = filename;        

# 응용프로그램 명
    AfxGetAppName();

// 실행 파일명을 제외한 경로
    int nIndex = string.ReverseFind('\\');
    string = string.Left(nIndex);

'Program > C | C++' 카테고리의 다른 글

BSTR 형변환  (0) 2008.01.16
문자열에 대한 정리  (0) 2008.01.16
CWaitCursor, GetTempFileName, LoadLibary, GetProcAdress  (0) 2008.01.16
:

CWaitCursor, GetTempFileName, LoadLibary, GetProcAdress

Program/C | C++ 2008. 1. 16. 09:38
CWaitCursor    모래시계 커서

GetTempFileName    임시파일 생성
        ( 경로, 파일명일부 텍스트, 0, 생성될 파일명을 저장할 메모리 주소)

LoadLibary    DLL로드
        (경로명)

GetProcAdress    유요한 DLL함수 주소
        (Dll 핸들, 함수명 )
: