Microsoft MVP성태의 닷넷 이야기
VC++: 10. 내가 생각해 보는 MFC OCX와 ATL DLL에 선택 기준 [링크 복사], [링크+제목 복사],
조회: 27503
글쓴 사람
정성태 (techsharer at outlook.com)
홈페이지
첨부 파일
 

제목이 너무 장황했는지 모르겠지만... ^^
우선, 각각의 특징 먼저 살펴 보자면.

MFC OCX
; OCX 파일 크기가 ATL DLL보다 다소 크다.
; MFC 관련 라이브러리를 그대로 이용할 수 있다. ( 사실 이것 때문에 크기가 크다 )

ATL DLL
; DLL 파일 크기가 작다.
; string 연산 같은 것은 별도의 STL 라이브러리를 써야 한다.
; VS.NET부터는 CString을 atlstr.h 파일을 포함하는 것으로 해결된다.
; MFC에서 제공되는 일부 기능들이 WTL이라는 Template 라이브러리로 제공되지만 MS는 더 이상의 업데이트를 약속하지 않았다.
; MFC 라이브러리를 사용할 수 없긴 하지만, 사실 User Interface를 가진 ActiveX 컨트롤의 제작보다는 UI 없는 COM 개체라든가, COM+ 등에서 사용되는 개체에 대한 수요가 더욱 많으므로, 현업에서 ATL만으로도 소화가능한 분야는 충분하다.

지금까지 ActiveX를 만들어 오신 분이라면... 위의 사항보다는 일단은 개인적인 취향에 의해서 결정되고 있지요. 저도 사실, 지금까지는 ATL만을 고집해 왔는데요.

그래도... MFC 라이브러리는 참 매력적이죠.
생산성 향상을 위해서라면 MFC OCX도 약간의 크기가 늘어나는 것을 제외하곤 나쁘지 않은 선택입니다. 더군다나 갈수록 빨라지는 네트워크 속도를 고려해보면, 100KB짜리 ATL DLL이나 300KB짜리 MFC OCX의 차이는 눈감아 줄만 합니다.

결론을 내려본다면... 처음 COM / ActiveX를 배우시는 분이라면 ATL DLL을 쓰실 것을 권합니다. 세세한 제어를 할 수 있기 때문에 COM에 대한 이해를 빨리 할 수가 있죠. 그에 비해 MFC OCX는 대부분의 것을 숨기기 때문에 라이브러리 자체에 대한 공부는 할 수 있어도 COM의 내부에 대한 공부는 어려울 수밖에 없습니다.

처음엔 ATL DLL을... 나중엔 MFC OCX를 적절하게 겸하면서. ^^










[최초 등록일: ]
[최종 수정일: 6/27/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)
13829정성태11/25/20246724스크립트: 67. 파이썬 - Windows 버전에서 함께 설치되는 py.exe
13828정성태11/25/20245218개발 환경 구성: 735. Azure - 압축 파일을 이용한 web app 배포 시 디렉터리 구분이 안 되는 문제파일 다운로드1
13827정성태11/25/20246036Windows: 273. Windows 환경의 파일 압축 방법 (tar, Compress-Archive)
13826정성태11/21/20246422닷넷: 2313. C# - (비밀번호 등의) Console로부터 입력받을 때 문자열 출력 숨기기(echo 끄기)파일 다운로드1
13825정성태11/21/20247063Linux: 110. eBPF / bpf2go - BPF_RINGBUF_OUTPUT / BPF_MAP_TYPE_RINGBUF 사용법
13824정성태11/20/20245457Linux: 109. eBPF / bpf2go - BPF_PERF_OUTPUT / BPF_MAP_TYPE_PERF_EVENT_ARRAY 사용법
13823정성태11/20/20246637개발 환경 구성: 734. Ubuntu에 docker, kubernetes (k3s) 설치
13822정성태11/20/20246509개발 환경 구성: 733. Windbg - VirtualBox VM의 커널 디버거 연결 시 COM 포트가 없는 경우
13821정성태11/18/20246116Linux: 108. Linux와 Windows의 프로세스/스레드 ID 관리 방식
13820정성태11/18/20246590VS.NET IDE: 195. Visual C++ - C# 프로젝트처럼 CopyToOutputDirectory 항목을 추가하는 방법
13819정성태11/15/20245158Linux: 107. eBPF - libbpf CO-RE의 CONFIG_DEBUG_INFO_BTF 빌드 여부에 대한 의존성
13818정성태11/15/20246756Windows: 272. Windows 11 24H2 - sudo 추가
13817정성태11/14/20245930Linux: 106. eBPF / bpf2go - (BPF_MAP_TYPE_HASH) Map을 이용한 전역 변수 구현
13816정성태11/14/20246872닷넷: 2312. C#, C++ - Windows / Linux 환경의 Thread Name 설정파일 다운로드1
13815정성태11/13/20245495Linux: 105. eBPF - bpf2go에서 전역 변수 설정 방법
13814정성태11/13/20246159닷넷: 2311. C# - Windows / Linux 환경에서 Native Thread ID 가져오기파일 다운로드1
13813정성태11/12/20246746닷넷: 2310. .NET의 Rune 타입과 emoji 표현파일 다운로드1
13812정성태11/11/202410392오류 유형: 933. Active Directory - The forest functional level is not supported.
13811정성태11/11/20245884Linux: 104. Linux - COLUMNS 환경변수가 언제나 80으로 설정되는 환경
13810정성태11/10/20246973Linux: 103. eBPF (bpf2go) - Tracepoint를 이용한 트레이스 (BPF_PROG_TYPE_TRACEPOINT)
13809정성태11/10/20246599Windows: 271. 윈도우 서버 2025 마이그레이션
13808정성태11/9/20246902오류 유형: 932. Linux - 커널 업그레이드 후 "error: bad shim signature" 오류 발생
13807정성태11/9/20245735Linux: 102. Linux - 커널 이미지 파일 서명 (Ubuntu 환경)
13806정성태11/8/20245902Windows: 270. 어댑터 상세 정보(Network Connection Details) 창의 내용이 비어 있는 경우
13805정성태11/8/20245504오류 유형: 931. Active Directory의 adprep 또는 복제가 안 되는 경우
13804정성태11/7/20247124Linux: 101. eBPF 함수의 인자를 다루는 방법
1  2  3  4  5  [6]  7  8  9  10  11  12  13  14  15  ...