Microsoft MVP성태의 닷넷 이야기
VC++: 10. 내가 생각해 보는 MFC OCX와 ATL DLL에 선택 기준 [링크 복사], [링크+제목 복사],
조회: 26398
글쓴 사람
정성태 (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

비밀번호

댓글 작성자
 




... 61  62  63  64  65  66  67  [68]  69  70  71  72  73  74  75  ...
NoWriterDateCnt.TitleFile(s)
12236정성태6/19/202018405오류 유형: 621. .NET Standard 대상으로 빌드 시 dynamic 예약어에서 컴파일 오류 - error CS0656: Missing compiler required member 'Microsoft.CSharp.RuntimeBinder.CSharpArgumentInfo.Create'
12235정성태6/19/202017591오류 유형: 620. Windows 10 - Inaccessible boot device 블루 스크린
12234정성태6/19/202016953개발 환경 구성: 494. NuGet - nuspec의 패키지 스키마 버전(네임스페이스) 업데이트 방법
12233정성태6/19/202017469오류 유형: 619. SQL 서버 - The transaction log for database '...' is full due to 'LOG_BACKUP'. - 두 번째 이야기
12232정성태6/19/202016162오류 유형: 618. SharePoint - StoreBusyRetryLater 오류
12231정성태6/15/202019447.NET Framework: 911. Console/Service Application을 위한 SynchronizationContext - AsyncContext
12230정성태6/15/202018318오류 유형: 617. IMetaDataImport::GetMethodProps가 반환하는 IL 코드 주소(RVA) 문제
12229정성태6/13/202020168.NET Framework: 910. USB/IP PROJECT를 이용해 C#으로 USB Keyboard + Mouse 가상 장치 만들기 [1]
12228정성태6/12/202019530.NET Framework: 909. C# - Source Generator를 적용한 XmlCodeGenerator파일 다운로드1
12227정성태6/12/202023462오류 유형: 616. Visual Studio의 느린 업데이트 속도에 대한 원인 분석 [5]
12226정성태6/11/202021525개발 환경 구성: 493. OpenVPN의 네트워크 구성 [4]파일 다운로드1
12225정성태6/11/202019458개발 환경 구성: 492. 윈도우에 OpenVPN 설치 - 클라이언트 측 구성
12224정성태6/11/202028201개발 환경 구성: 491. 윈도우에 OpenVPN 설치 - 서버 측 구성 [1]
12223정성태6/9/202023860.NET Framework: 908. C# - Source Generator 소개 [10]파일 다운로드2
12222정성태6/3/202017360VS.NET IDE: 146. error information: "CryptQueryObject" (-2147024893/0x80070003)
12221정성태6/3/202017115Windows: 170. 비어 있지 않은 디렉터리로 symbolic link(junction) 연결하는 방법
12220정성태6/3/202020873.NET Framework: 907. C# DLL로부터 TLB 및 C/C++ 헤더 파일(TLH)을 생성하는 방법
12219정성태6/1/202019684.NET Framework: 906. C# - lock (this), lock (typeof(...))를 사용하면 안 되는 이유파일 다운로드1
12218정성태5/27/202019133.NET Framework: 905. C# - DirectX 게임 클라이언트 실행 중 키보드 입력을 감지하는 방법 [3]
12217정성태5/24/202017183오류 유형: 615. Transaction count after EXECUTE indicates a mismatching number of BEGIN and COMMIT statements. Previous count = 0, current count = 1.
12216정성태5/15/202020747.NET Framework: 904. USB/IP PROJECT를 이용해 C#으로 USB Keyboard 가상 장치 만들기 [14]파일 다운로드1
12215정성태5/12/202026688개발 환경 구성: 490. C# - (Wireshark의) USBPcap을 이용한 USB 패킷 모니터링 [10]파일 다운로드1
12214정성태5/5/202018405개발 환경 구성: 489. 정식 인증서가 있는 경우 Device Driver 서명하는 방법 (2) - UEFI/SecureBoot [1]
12213정성태5/3/202019528개발 환경 구성: 488. (User-mode 코드로 가상 USB 장치를 만들 수 있는) USB/IP PROJECT 소개
12212정성태5/1/202016728개발 환경 구성: 487. UEFI / Secure Boot 상태인지 확인하는 방법
12211정성태4/27/202019283개발 환경 구성: 486. WSL에서 Makefile로 공개된 리눅스 환경의 C/C++ 소스 코드 빌드
... 61  62  63  64  65  66  67  [68]  69  70  71  72  73  74  75  ...