Microsoft MVP성태의 닷넷 이야기
VC++: 22. IDL Library 절 [링크 복사], [링크+제목 복사],
조회: 20734
글쓴 사람
정성태 (techsharer at outlook.com)
홈페이지
첨부 파일
 

  
부모글 보이기/감추기
[이 토픽은 제가 뉴스그룹에 했던 답변내용입니다.]

=============================================================
 
library 내부에서 정의되는 인터페이스 및 참조되는 외부 인터페이스들은 명시적으로 type library로 내보내지게 됩니다.
즉, library 외부에서 인터페이스를 정의하고 내부에 선언하지 않았다면 type library에는 누락되는 것이죠.

이로 인해, 명시된 인터페이스들이 type library에서 그대로 참조되긴 하지만... 아닐 수도 있는 유연성을 놓은 것입니다.
또한, 인터페이스 정의만 포함된 IDL 파일을 만들고 다른 IDL 파일에서 import(C++의 include 처럼)시켜서 컴파일 할 수 있습니다. library 블록은 두개 이상 나올 수 없기 때문에 그렇게 할 수는 없습니다.

... 그러고 보면,,, 진정한 재활용 측면에서 본다면, 인터페이스 정의되는 IDL 파일을 분리하고, 분리된 IDL 파일을 import시키는 type library 생성용 idl 파일을 두는 것을 생각해 볼수도 있겠습니다. (한번도 그렇게 해본 적이 없군요. ^^;)

좀 더 자세한 사항은.. "https://docs.microsoft.com/en-us/windows/win32/midl/midl-language-reference?WT.mc_id=DT-MVP-4038148"을 참조하십시오.

덕분에... 옛날 기억 떠올리면서 한번 보게 되었습니다.^^




      .NETXPERT http://www.dotnetxpert.com
      E-MAIL kevin@dotnetxpert.com
      My Blog https://www.sysnet.pe.kr

--------------------------------------------------------------------------
      MCSD.NET, MVP[VC++]

  "UhmTaiJoon" <c_user@hanmail.com> wrote in message news:E847D3F5-5BB6-4529-8748-BC3F8C964E95@microsoft.com...
  지금 CONNECTION POINTER 부분을 보고 있는데, 지금까지 본 샘플 소스들을 보면 이벤트에 대한 인터페이스는 libary
  내부에서 선언을 하더군요.

  connection pointer 인터페이스는 이렇게 작성하는 것이 정석인지요?

  그리고, 또 하나 의문이, 다른 인터페이스는 library에는 인터페이스만 선언만 명시가 되고, 인터페이스 정의은 library 키워드
  상단에 작성이 되어 있습니다.

  library 안에 선언만 하고, library 상단에 정의 한것과 library 내부에서 선언과 동시에 정의한 경우의 차이점은 무엇인가요?

  여러분들의 답변 부탁드리겠습니다.

  모두들 즐샾되세요 ^^;;


  --








[최초 등록일: ]
[최종 수정일: 7/10/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)
13971정성태7/17/2025469닷넷: 2343. C# 14 - (2) 속성 구문에서 문맥 키워드로 추가되는 field 예약어파일 다운로드1
13970정성태7/17/2025496닷넷: 2342. C# 14 - (1) (예약)
13969정성태7/17/2025444닷넷: 2341. snap으로 설치한 .NET 리눅스 실행 환경
13968정성태7/16/2025451오류 유형: 969. lddtree - TypeError: 'type' object is not subscriptable
13967정성태7/16/2025517오류 유형: 968. snap으로 설치한 "dotnet run" 실행 시 "undefined symbol: _dl_audit_symbind_alt, version GLIBC_PRIVATE" 오류
13966정성태7/15/2025982디버깅 기술: 223. WinDbg - .kframes 명령어
13965정성태7/11/20251027오류 유형: 967. 디버깅 모드로 실행 시 "Could not find file 'C:\Program Files\IIS Express\Oracle.DataAccess.Common.Configuration.Section.xsd'" 예외
13964정성태7/10/20251591닷넷: 2340. C# - Win32 Multimedia Timer 주기파일 다운로드1
13963정성태7/8/20251216VS.NET IDE: 202. Visual Studio 2022 + Copilot 기본 사용법
13962정성태7/7/20251302스크립트: 79. 파이썬 - onnxruntime_genai에서 지원하지 않는 모델 사용
13961정성태7/5/20251177디버깅 기술: 222. WinDbg 분석 사례 - IISreset 시점에 w3wp.exe의 crash 발생
13960정성태7/3/20251820개발 환경 구성: 752. ProcDump - C/C++ 예외 코드 필터를 지정한 덤프 생성 [2]
13959정성태6/25/20251383오류 유형: 966. Ubuntu - ping: connect: Network is unreachable
13958정성태6/21/20251877닷넷: 2339. C# - Phi-4-multimodal 모델의 GPU 가속 방법 (ORT 사용)파일 다운로드1
13957정성태6/20/20251871닷넷: 2338. C# / Foundry Local - Phi-4-multimodal 모델을 사용하는 방법 [1]
13956정성태6/19/20251724개발 환경 구성: 751. Triton Inference Server의 Python Backend 프로세스
13955정성태6/18/20251854오류 유형: 965. Hugging Face 모델 다운로드 시 "requests.exceptions.HTTPError: 401 Client Error: Unauthorized for url: ..." 오류
13954정성태6/18/20251714닷넷: 2337. C# - Hugging Face에 공개된 LLM 모델을 Foundry Local에서 사용하는 방법파일 다운로드1
13953정성태6/16/20251500스크립트: 78. 파이썬 - 소스 코드의 파일 경로를 지정한 모듈 로드
13952정성태6/15/20251975닷넷: 2336. C# - IValueTaskSource로 인해 주의가 필요한 ValueTask 호출파일 다운로드1
13951정성태6/15/20251800오류 유형: 964. Outlook - 일정이 "You cannot make changes to contents of this read-only folder." 오류 메시지로 삭제가 안 되는 경우
13950정성태6/12/20252536닷넷: 2335. C# - 간단하게 구현해 보는 IValueTaskSource 예제파일 다운로드1
13949정성태6/11/20252481오류 유형: 963. SignTool - "Error: SignerSign() failed." (-2146869243/0x80096005)
13948정성태6/10/20251823오류 유형: 962. 파이썬 - Linux 환경 + TCP 서버 소켓을 사용하는 프로세스 종료 후 재실행하는 경우 "OSError: [Errno 98] Address already in use" 오류 발생
13947정성태6/9/20252432개발 환경 구성: 750. 파이썬 - Azure App Service에 응용 프로그램 배포 후의 환경
[1]  2  3  4  5  6  7  8  9  10  11  12  13  14  15  ...