Microsoft MVP성태의 닷넷 이야기
VS.NET IDE: 39. VS.NET 2003/2005에서도 제공되는 VS 6.0 MFC ClassWizard [링크 복사], [링크+제목 복사],
조회: 14262
글쓴 사람
정성태 (techsharer at outlook.com)
홈페이지
첨부 파일
 


가끔, 이거 관련해서 질문 주시는 분들이 많은 것 같습니다.
아예 이참에 정리를 해버려야겠습니다. ^^;

VS 6.0 시절에는 웹 프로그래밍과 윈도우즈 클라이언트 프로그래밍이 별도로 나뉘던 시절이었습니다. 개발툴도 VS 6.0과 Visual InterDev라고 나뉘어서 사용되어졌지요.

그러던 것이 .NET이라는 개발 플랫폼이 나오면서 통합되게 되었습니다. 이제 더 이상 Visual Studio는 MFC만의 것이 아니었기 때문에 관련 기능들에 대한 사용자 인터페이스 기능이 통합되어야 할 필요가 발생했지요.

이런저런 이유로 "Class Wizard"라는 것을 메뉴와 대화창 자체를 없애긴 했는데, 그렇다고 아예 그에 상응하는 기능조차 제공하지 않는다면, VS.NET 2003/2005는 오히려 불편한 개발툴이라고 인식될 수도 있을 것입니다.

아무튼, VS.NET 2003/2005 개발팀은 기존의 Class Wizard의 구현 위치를 대체할 만한 곳으로 "속성" 창을 택하게 되었습니다. 그럼, 어떻게 되는지 그림을 통해서 알아보도록 하죠.

아래의 그림은 기존 VS 6.0에서 MFC를 위해 제공되던 Class Wizard입니다.

[그림 1]
VS 6.0에서 제공되는 Class Wizard

실제로, VS.NET 2003/2005에는 어떤 식으로든 위의 기능들 대부분이 그대로 구현되어져 있습니다. 이 중에서 대표적으로 2가지 기능만을 설명하겠습니다.

첫 번째로, "기반 클래스에서 제공하는 virtual 함수들에 대한 재정의 기능"입니다. 위의 그림에서는 CAboutDlg를 선택하고, 오른쪽 리스트 박스의 상단 네모 상자 부분에 해당하는 함수 추가 기능입니다. 이와 동등한 VS.NET 2003/2005 기능은 아래의 그림과 같이 속성창의 확장 기능을 통해서 구현하고 있습니다.

[그림 2]
Class Wizard 함수 재정의 - VS.NET 2005

두 번째로, "윈도우 이벤트 메시지 핸들러 정의"입니다. [그림 1]에서는 오른쪽 리스트 상자의 하위 네모 영역에 해당하는 것인데요. 역시 다음과 같이 속성창의 확장 기능으로 구현되어져 있습니다.

[그림 3]
Class Wizard 윈도우 이벤트 핸들러 - VS.NET 2005







[최초 등록일: ]
[최종 수정일: 7/8/2021]

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

비밀번호

댓글 작성자
 




1  2  3  [4]  5  6  7  8  9  10  11  12  13  14  15  ...
NoWriterDateCnt.TitleFile(s)
13556정성태2/17/20242144Windows: 257. Windows - Symbolic (hard/soft) Link 및 Junction 차이점
13555정성태2/15/20242405닷넷: 2216. C# - SemaphoreSlim 사용 시 주의점
13554정성태2/15/20242097VS.NET IDE: 189. Visual Studio - 닷넷 소스코드 디컴파일 찾기가 안 될 때
13553정성태2/14/20242152닷넷: 2215. windbg - thin/fat lock 없이 동작하는 Monitor.Wait + Pulse
13552정성태2/13/20242058닷넷: 2214. windbg - Monitor.Enter의 thin lock과 fat lock
13551정성태2/12/20242380닷넷: 2213. ASP.NET/Core 웹 응용 프로그램 - 2차 스레드의 예외로 인한 비정상 종료
13550정성태2/11/20242579Windows: 256. C# - Server socket이 닫히면 Accept 시켰던 자식 소켓이 닫힐까요?
13549정성태2/3/20242975개발 환경 구성: 706. C# - 컨테이너에서 실행하기 위한 (소켓) 콘솔 프로젝트 구성
13548정성태2/1/20242736개발 환경 구성: 705. "Docker Desktop for Windows" - ASP.NET Core 응용 프로그램의 소켓 주소 바인딩(IPv4/IPv6 loopback, Any)
13547정성태1/31/20242472개발 환경 구성: 704. Visual Studio - .NET 8 프로젝트부터 dockerfile에 추가된 "USER app" 설정
13546정성태1/30/20242298Windows: 255. (디버거의 영향 등으로) 대상 프로세스가 멈추면 Socket KeepAlive로 연결이 끊길까요?
13545정성태1/30/20242193닷넷: 2212. ASP.NET Core - 우선순위에 따른 HTTP/HTTPS 호스트:포트 바인딩 방법
13544정성태1/30/20242220오류 유형: 894. Microsoft.Data.SqlClient - Could not load file or assembly 'System.Security.Permissions, ...'
13543정성태1/30/20242266Windows: 254. Windows - 기본 사용 중인 5357 포트 비활성화는 방법
13542정성태1/30/20242260오류 유형: 893. Visual Studio - Web Application을 실행하지 못하는 IISExpress - 두 번째 이야기
13541정성태1/29/20242395VS.NET IDE: 188. launchSettings.json의 useSSL 옵션
13540정성태1/29/20242512Linux: 69. 리눅스 - "Docker Desktop for Windows" Container 환경에서 IPv6 Loopback Address 바인딩 오류
13539정성태1/26/20242485개발 환경 구성: 703. Visual Studio - launchSettings.json을 이용한 HTTP/HTTPS 포트 바인딩
13538정성태1/25/20242709닷넷: 2211. C# - NonGC(FOH) 영역에 .NET 개체를 생성파일 다운로드1
13537정성태1/24/20242769닷넷: 2210. C# - Native 메모리에 .NET 개체를 생성파일 다운로드1
13536정성태1/23/20242775닷넷: 2209. .NET 8 - NonGC Heap / FOH (Frozen Object Heap) [1]
13535정성태1/22/20242715닷넷: 2208. C# - GCHandle 구조체의 메모리 분석
13534정성태1/21/20242472닷넷: 2207. C# - SQL Server DB를 bacpac으로 Export/Import파일 다운로드1
13533정성태1/18/20242623닷넷: 2206. C# - TCP KeepAlive의 서버 측 구현파일 다운로드1
13532정성태1/17/20242596닷넷: 2205. C# - SuperSimpleTcp 사용 시 주의할 점파일 다운로드1
13531정성태1/16/20242612닷넷: 2204. C# - TCP KeepAlive에 새로 추가된 Retry 옵션파일 다운로드1
1  2  3  [4]  5  6  7  8  9  10  11  12  13  14  15  ...